加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

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

发布时间:2019-10-22 12:53:43 所属栏目:MySql教程 来源:波波说运维
导读:副标题#e# 【大咖·来了 第7期】10月24日晚8点观看《智能导购对话机器人实践》 触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件
副标题[/!--empirenews.page--] 【大咖·来了 第7期】10月24日晚8点观看《智能导购对话机器人实践》

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

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

一、触发器的优点

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

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

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

二、触发器的分类

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

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

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读取

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

四、创建触发器

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触发器

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读