SQL Server 通过触发器用来保证业务逻辑和数据的完整性。在SQL Server中,触发器是一种特殊类型的存储过程,可在执行语言事件时自动触发。SQL Server中触发器包括三种:DML触发器、DDL触发器和登录触发器。
DML触发器:执行DML语句触发执行,例如操作数据表或视图的insert、update、delete语句,不包含select。
DDL触发器:执行DDL语句时触发执行,例如create table等语句。
登录触发器:在用户登录SQL Server实例创建会话时触发。
SQL Server将触发器和触发它的语句放在一个可回滚事务中,如果触发器发生异常,则与该触发器相关的语句自动回滚。
DML的功能(优点):
实现表的级联更改,实现与外键约束相似的功能(如果外键可以约束,则不推荐使用触发器)
防止恶意或错误的insert、update、delete操作。触发器比check约束更加强大,触发器可以引用其它数据表,执行更加复杂的限制,而check约束不能引用其它表。
可以获取到更改前和修改后的数据,根据差异采取措施,决定是commit,还是rollback
一个表支持创建多个同类型的DML触发器
注意:有日志操作的行为才会激活触发器。例如truncate table删除表中所有数据,并没有执行日志操作,所以不会激活delete触发器。
DML触发器分为:
after触发器(之后触发) insert触发器
update触发器
delete触发器
instead of 触发器 (之前触发)
其中after触发器要求只有执行某一操作insert、update、delete之后触发器才被触发,且只能定义在表上。而instead of触发器表示并不执行其定义的操作(insert、update、delete)而仅是执行触发器本身。既可以在表上定义instead of触发器,也可以在视图上定义。
触发器有两个特殊的表:插入表(instered表)和删除表(deleted表)。这两张是逻辑表也是虚表。有系统在内存中创建者两张表,不会存储在数据库中。而且两张表的都是只读的,只能读取数据而不能修改数据。这两张表的结果总是与被改触发器应用的表的结构相同。当触发器完成工作后,这两张表就会被删除。Inserted表的数据是插入或是修改后的数据,而deleted表的数据是更新前的或是删除的数据。
Inserted逻辑表 Deleted逻辑表
增加记录(insert) 存放增加的记录 无
删除记录(delete) 无 存放被删除的记录
修改记录(update) 存放更新后的记录 存放更新前的记录
Update数据的时候就是先删除表记录,然后增加一条记录。这样在inserted和deleted表就都有update后的数据记录了。注意的是:触发器本身就是一个事务,所以在触发器里面可以对修改数据进行一些特殊的检查。如果不满足可以利用事务回滚,撤销操作。
insert触发器,会在inserted表中添加一条刚插入的记录。
delete触发器会在删除数据的时候,将刚才删除的数据保存在deleted表中。
update触发器会在更新数据后,将更新前的数据保存在deleted表中,更新后的数据保存在inserted表中。
更新列级触发器可以用update是否判断更新列记录;
instead of 触发器表示并不执行其定义的操作(insert、update、delete)而仅是执行触发器本身的内容。
语法:
本文代码来源:http://www.cnblogs.com/hoojo/archive/2011/07/20/2111316.html
2021年9月 北京、西安两地,高薪诚聘 .NET工程师,请私信联系!
如果认为此文对您有帮助,别忘了支持一下哦!
声明:本博客原创文字只代表本人工作中在某一时间内总结的观点或结论,与本人所在单位没有直接利益关系。转载时请在文章页面明显位置给出原文链接。