返回顶部
首页 > 资讯 > 数据库 >SQL Server数据库中有哪些触发器
  • 152
分享到

SQL Server数据库中有哪些触发器

2024-04-02 19:04:59 152人浏览 薄情痞子
摘要

这篇文章将为大家详细讲解有关SQL Server数据库中有哪些触发器,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、触发器的优点1. 触发器是自动的。当对

这篇文章将为大家详细讲解有关SQL Server数据库中有哪些触发器,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

一、触发器的优点

1. 触发器是自动的。当对表中的数据做了任何修改之后立即被激活。

2. 触发器可以通过数据库中的相关表进行层叠修改。

3. 触发器可以强制限制。这些限制比用CHECK约束所定义的更复杂。与CHECK约束不同的是,触发器可以引用其他表中的列。

二、触发器的分类

sqlServer包括三种常规类型的触发器:DML触发器、DDL触发器和登录触发器。

SQL Server数据库中有哪些触发器

1. DML(数据操作语言,Data Manipulation Language)触发器

DML触发器是一些附加在特定表或视图上的操作代码,当数据库服务器中发生数据操作语言事件时执行这些操作。SqlServer中的DML触发器有三种:

  • insert触发器:向表中插入数据时被触发;

  • delete触发器:从表中删除数据时被触发;

  • update触发器:修改表中数据时被触发。

当遇到下列情形时,应考虑使用DML触发器:

  • 通过数据库中的相关表实现级联更改

  • 防止恶意或者错误的insert、update和delete操作,并强制执行check约束定义的限制更为复杂的其他限制。

  • 评估数据修改前后表的状态,并根据该差异才去措施。

2. DDL(数据定义语言,Data Definition Language)触发器

DDL触发器是当服务器或者数据库中发生数据定义语言(主要是以create,drop,alter开头的语句)事件时被激活使用,使用DDL触发器可以防止对数据架构进行的某些更改或记录数据中的更改或事件操作。

3. 登录触发器

登录触发器将为响应 LOGIN 事件而激发存储过程。与 SQL Server  实例建立用户会话时将引发此事件。登录触发器将在登录的身份验证阶段完成之后且用户会话实际建立之前激发。因此,来自触发器内部且通常将到达用户的所有消息(例如错误消息和来自  PRINT 语句的消息)会传送到 SQL Server 错误日志。如果身份验证失败,将不激发登录触发器。

三、触发器的工作原理

[DELETE, INSERT, UPDATE]对应为当执行删除、插入、更新三种动作时被触发

执行insert时,获取插入后的数据,可用select*from inserted读取

执行delete时,获取删除前的数据,可用select*from deleted读取

执行update时,获取更新前的数据,可用select*from deleted读取,获取更新后数据,可用select*from  inserted读取

SQL Server数据库中有哪些触发器

四、创建触发器

1. 创建触发器的语法:

CREATE TRIGGER trigger_name  ON table_name  [WITH ENCRYPTioN]  FOR | AFTER | INSTEAD OF [DELETE, INSERT, UPDATE]  AS   T-SQL语句 Go --with encryption 表示加密触发器定义的sql文本 --delete,insert,update指定触发器的类型

2. 创建insert触发器

--创建insert触发器 create trigger trig_insert on student after insert as begin  if object_id(N'student_sum',N'U') is null--判断student_sum表是否存在  create table student_sum(stuCount int default(0));--创建存储学生人数的student_sum表  declare @stuNumber int;  select @stuNumber = count(*)from student;  if not exists (select * from student_sum)--判断表中是否有记录  insert into student_sum values(0);  update student_sum set stuCount =@stuNumber; --把更新后总的学生数插入到student_sum表中 end --测试触发器trig_insert-->功能是向student插入数据的同时级联插入到student_sum表中,更新stuCount --因为是后触发器,所以先插入数据后,才触发触发器trig_insert; insert into student(stu_name,stu_gender,stu_age)values('吕布','男',30); select stuCount 学生总人数 from student_sum;  insert into student(stu_name,stu_gender,stu_age)values('貂蝉','女',30);  select stuCount 学生总人数 from student_sum; insert into student(stu_name,stu_gender,stu_age)values('曹阿瞒','男',40);  select stuCount 学生总人数 from student_sum;

3. 创建delete触发器

用户执行delete操作,就会激活delete触发器,从而控制用户能够从数据库中删除数据记录,触发delete触发器后,用户删除的记录会被添加到deleted表中,原来表的相应记录被删除,所以在deleted表中查看删除的记录。

--创建delete触发器 create trigger trig_delete on student  after delete as begin  select stu_id as 已删除的学生编号,stu_name stu_gender,stu_age  from deleted end; --执行一一条delete语句触发trig_delete触发器 delete from student where stu_id=1;

4. 创建UPDATE触发器

update触发器是当用户在指定表上执行update语句时被调用被调用,这种类型的触发器用来约束用户对数据的修改。update触发器可以执行两种操作:更新前的记录存储在deleted表中,更新后的记录存储在inserted表中。

--创建update触发器 create trigger trig_update on student after update as begin  declare @stuCount int;  select @stuCount=count(*) from student;  update student_sum set stuCount =@stuCount;  select stu_id as 更新前学生编号,stu_name as 更新前学生姓名 from deleted  select stu_id as 更新后学生编号,stu_name as 更新后学生姓名 from inserted end --创建完成,执行一条update语句触发trig_update触发器 update student set stu_name='张飞' where stu_id=2;

五、管理触发器

1. 查看触发器

(1).查看数据库中所有的触发器

--查看数据库中所有的触发器 use 数据库名 go select * from sysobjects where xtype='TR'

sysobjects 保存着数据库的对象,其中 xtype 为 TR 的记录即为触发器对象。在 name 一列,我们可以看到触发器名称。

(2).sp_helptext 查看触发器内容

use 数据库名 go exec sp_helptext '触发器名称'

将会以表的样式显示触发器内容。

除了触发器外,sp_helptext 还可以显示 规则、默认值、未加密的存储过程、用户定义函数、视图的文本。

(3).sp_helptrigger 用于查看触发器的属性

sp_helptrigger 有两个参数:第一个参数为表名;第二个为触发器类型,为 char(6) 类型,可以是  INSERT、UPDATE、DELETE,如果省略则显示指定表中所有类型触发器的属性。

use 数据库名 go exec sp_helptrigger tableName

2. 禁用启用触发器

  • 禁用:alter table 表名 disable trigger 触发器名称

  • 启用:alter table 表名 enable trigger 触发器名称

如果有多个触发器,则各个触发器名称之间用英文逗号隔开。

如果把“触发器名称”换成“ALL”,则表示禁用或启用该表的全部触发器。

3. 修改触发器

--修改触发器语法 ALTER TRIGGER trigger_name   ON table_name   [ WITH ENCRYPTION ]   FOR {[DELETE][,][INSERT][,][UPDATE]}  AS  sql_statement;

4. 删除触发器

 --语法格式:  DROP TRIGGER { trigger } [ ,...n ] 参数:  trigger: 要删除的触发器名称  n:表示可以删除多个触发器的占位符

关于SQL Server数据库中有哪些触发器就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: SQL Server数据库中有哪些触发器

本文链接: https://lsjlt.com/news/58807.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • SQL Server数据库中有哪些触发器
    这篇文章将为大家详细讲解有关SQL Server数据库中有哪些触发器,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、触发器的优点1. 触发器是自动的。当对...
    99+
    2024-04-02
  • SQL Server中触发器的类型有哪些
    这篇文章给大家分享的是有关SQL Server中触发器的类型有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。触发器的类型有:DML触发器、DDL触发器和登录触发器。触发器(t...
    99+
    2024-04-02
  • 数据库触发器的作用有哪些
    数据库触发器的作用主要有以下几个方面: 数据完整性约束:触发器可以用于检查和维护数据的完整性约束,例如主键约束、外键约束、唯一性...
    99+
    2023-10-24
    数据库
  • SQL Server数据库中有哪些恢复模式
    SQL Server数据库中有哪些恢复模式,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1.Simple 简单恢复模式,Sim...
    99+
    2024-04-02
  • sql数据库触发器如何写
    编写SQL数据库触发器可以使用以下语法: CREATE TRIGGER trigger_name {BEFORE | AFTER} ...
    99+
    2023-10-24
    sql数据库
  • sql触发器的使用有哪些
    SQL触发器是数据库中的一种特殊对象,它们可以在数据库中的某个特定事件发生时自动执行一系列的操作。以下是SQL触发器的一些常见使用场...
    99+
    2023-10-25
    sql
  • SQL触发器的用途有哪些
    SQL触发器是一种特殊的存储过程,它会在某种特定的数据库事件发生时自动执行。其主要用途包括: 数据完整性约束:触发器可用于强制执...
    99+
    2023-10-26
    SQL
  • 数据库中存储过程和触发器有哪些区别
    这篇文章主要讲解了“数据库中存储过程和触发器有哪些区别”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“数据库中存储过程和触发器有哪些区别”吧!什么是触发器?触...
    99+
    2024-04-02
  • SQL Server中的数据类型有哪些
    这篇文章主要介绍了SQL Server中的数据类型有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SQL Server中的数据类型有哪些文章都会有所收获,下面我们一起来看看吧。T-SQL...
    99+
    2023-06-30
  • 云数据库SQL Server租用有哪些优势
    云数据库SQL Server租用的优势包括:1. 灵活性:云数据库SQL Server提供了按需使用的租用模式,可以根据业务需求快速...
    99+
    2023-09-21
    云数据库 SQL Server
  • SQL SERVER 数据类型有哪些
    SQL SERVER 数据类型有哪些,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。数据类型 类型 描 述 bit 整型 bit...
    99+
    2024-04-02
  • Sql Server有哪些数据类型
    这篇文章将为大家详细讲解有关Sql Server有哪些数据类型,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Character 字符串:数据类型描述存储char(n)固定长度的字符串。...
    99+
    2023-06-29
  • sql中怎么创建sqlserver数据库触发器
    这篇文章将为大家详细讲解有关sql中怎么创建sqlserver数据库触发器,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。代码如下: --会员表 if ob...
    99+
    2024-04-02
  • 数据库中触发器有什么用
    这篇文章主要介绍了数据库中触发器有什么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。触发器有两个稳态,可分别表示二进制数码0和1,无外触发...
    99+
    2024-04-02
  • 怎么创建sql数据库触发器
    本篇文章给大家分享的是有关怎么创建sql数据库触发器,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。创建sql数据库触发器的方法是:【creat...
    99+
    2024-04-02
  • oracle数据库触发器在哪
    oracle 数据库中的触发器位于数据字典中,具体位置是在 user_triggers 表中。访问方法包括查询特定表的触发器或查询所有表的触发器。user_triggers 表包含有关触...
    99+
    2024-04-08
    oracle
  • SQL触发器的优缺点有哪些
    这篇文章给大家分享的是有关SQL触发器的优缺点有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1.SQL触发器简介:SQL触发器是存储在数据库目录中的一组SQL语句。每当与表...
    99+
    2024-04-02
  • SQL Server数据库sql优化注意事项都有哪些
    SQL Server数据库sql优化注意事项都有哪些,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。今天主要分享下sqlserver数据库在做s...
    99+
    2024-04-02
  • Sql Server中如何使用触发器
    本篇文章为大家展示了Sql Server中如何使用触发器,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Sql Server为每个触发器都创建了两个专用表:Inser...
    99+
    2024-04-02
  • mysql中有哪些触发器
    这篇文章主要介绍了mysql中有哪些触发器,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。mysql触发器有六种,分别是:1、Before Ins...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作