设为首页收藏本站

EPS数据狗论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1274|回复: 0

超详细的SqlServer数据库触发器总结

[复制链接]

38

主题

328

金钱

536

积分

初级用户

发表于 2019-10-23 16:11:45 | 显示全部楼层 |阅读模式

触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,当对一个表进行操作( insert,delete, update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。
1.jpg

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

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

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

二、触发器的分类
SqlServer包括三种常规类型的触发器:DML触发器、DDL触发器和登录触发器。
2.jpg
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读取
3.jpg

四、创建触发器
1. 创建触发器的语法:
  1. CREATE TRIGGER trigger_name
  2. ON table_name
  3. [WITH ENCRYPTION]
  4. FOR | AFTER | INSTEAD OF [DELETE, INSERT, UPDATE]
  5. AS  
  6. T-SQL语句
  7. GO
  8. --with encryption 表示加密触发器定义的sql文本
  9. --delete,insert,update指定触发器的类型
复制代码


2. 创建insert触发器
  1. --创建insert触发器
  2. create trigger trig_insert
  3. on student
  4. after insert
  5. as
  6. begin
  7. if object_id(N'student_sum',N'U') is null--判断student_sum表是否存在
  8. create table student_sum(stuCount int default(0));--创建存储学生人数的student_sum表
  9. declare @stuNumber int;
  10. select @stuNumber = count(*)from student;
  11. if not exists (select * from student_sum)--判断表中是否有记录
  12. insert into student_sum values(0);
  13. update student_sum set stuCount =@stuNumber; --把更新后总的学生数插入到student_sum表中
  14. end
  15. --测试触发器trig_insert-->功能是向student插入数据的同时级联插入到student_sum表中,更新stuCount
  16. --因为是后触发器,所以先插入数据后,才触发触发器trig_insert;
  17. insert into student(stu_name,stu_gender,stu_age)values('吕布','男',30);
  18. select stuCount 学生总人数 from student_sum;  
  19. insert into student(stu_name,stu_gender,stu_age)values('貂蝉','女',30);  
  20. select stuCount 学生总人数 from student_sum;
  21. insert into student(stu_name,stu_gender,stu_age)values('曹阿瞒','男',40);  
  22. select stuCount 学生总人数 from student_sum;
复制代码


3. 创建delete触发器
用户执行delete操作,就会激活delete触发器,从而控制用户能够从数据库中删除数据记录,触发delete触发器后,用户删除的记录会被添加到deleted表中,原来表的相应记录被删除,所以在deleted表中查看删除的记录。
  1. --创建delete触发器
  2. create trigger trig_delete
  3. on student  
  4. after delete
  5. as
  6. begin
  7. select stu_id as 已删除的学生编号,stu_name stu_gender,stu_age
  8. from deleted
  9. end;
  10. --执行一一条delete语句触发trig_delete触发器
  11. delete from student where stu_id=1;
复制代码


4. 创建UPDATE触发器
update触发器是当用户在指定表上执行update语句时被调用被调用,这种类型的触发器用来约束用户对数据的修改。update触发器可以执行两种操作:更新前的记录存储在deleted表中,更新后的记录存储在inserted表中。
  1. --创建update触发器
  2. create trigger trig_update
  3. on student
  4. after update
  5. as
  6. begin
  7. declare @stuCount int;
  8. select @stuCount=count(*) from student;
  9. update student_sum set stuCount =@stuCount;
  10. select stu_id as 更新前学生编号,stu_name as 更新前学生姓名 from deleted
  11. select stu_id as 更新后学生编号,stu_name as 更新后学生姓名 from inserted
  12. end
  13. --创建完成,执行一条update语句触发trig_update触发器
  14. update student set stu_name='张飞' where stu_id=2;
复制代码


五、管理触发器
1. 查看触发器
(1).查看数据库中所有的触发器
  1. --查看数据库中所有的触发器
  2. use 数据库名
  3. go
  4. select * from sysobjects where xtype='TR'
复制代码

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

(2).sp_helptext 查看触发器内容
  1. use 数据库名
  2. go
  3. exec sp_helptext '触发器名称'
复制代码

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

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

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

sp_helptrigger 有两个参数:第一个参数为表名;第二个为触发器类型,为 char(6) 类型,可以是 INSERT、UPDATE、DELETE,如果省略则显示指定表中所有类型触发器的属性。
  1. use 数据库名
  2. go
  3. exec sp_helptrigger tableName
复制代码


2. 禁用启用触发器
禁用:alter table 表名 disable trigger 触发器名称
启用:alter table 表名 enable trigger 触发器名称
如果有多个触发器,则各个触发器名称之间用英文逗号隔开。

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

3. 修改触发器
  1. --修改触发器语法
  2. ALTER TRIGGER trigger_name  
  3. ON table_name  
  4. [ WITH ENCRYPTION ]  
  5. FOR {[DELETE][,][INSERT][,][UPDATE]}
  6. AS
  7. sql_statement;
复制代码


4. 删除触发器
  1. --语法格式:
  2. DROP TRIGGER { trigger } [ ,...n ]
  3. 参数:
  4. trigger: 要删除的触发器名称
  5. n:表示可以删除多个触发器的占位符  
复制代码
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

站长推荐上一条 /1 下一条

客服中心
关闭
在线时间:
周一~周五
8:30-17:30
QQ群:
653541906
联系电话:
010-85786021-8017
在线咨询
客服中心

意见反馈|网站地图|手机版|小黑屋|EPS数据狗论坛 ( 京ICP备09019565号-3 )   

Powered by BFIT! X3.4

© 2008-2028 BFIT Inc.

快速回复 返回顶部 返回列表