触发器是一种特殊的存储过程,它不需要用户去用过事件去主动触发,而是在事件进行出发而自动调用的。
触发器分DDLDML两种。
DDL是一种为了响应各种数据定义语言 (DDL) 事件而激发的触发器。主要是以DROPALTERCREATE这种关键字来激发的。
DML是一种为了响应各种数据操纵语言 (DML) 事件而激发的触发器。主要是以INSERTDELETEUPDATE这种关键字来激发的。

DML触发器分为AFTERINSTEAD OF两种:
AFTER触发器只有被INSERT触发器、UPDATE触发器、DELETE触发器之后触发某一触发器触法之后才能触发。且只能定义在表上。
instead of触发器表示并不执行其定义的操作(insertupdatedelete)而仅是执行触发器本身。既可以在表上定义instead of触发器,也可以在视图上定义。
触发器由两个名叫INSERTDELETE的虚表,有系统在内存中创建者两张表,不会存储在数据库中。而且两张表的都是只读的,只能读取数据而不能修改数据。这两张表的结果总是与被改触发器应用的表的结构相同。当触发器完成工作后,这两张表就会被删除。
对表的操作
Inserted逻辑表
Deleted逻辑表
增加记录(insert
存放增加的记录
删除记录(delete
存放被删除的记录
修改记录(update
存放更新后的记录
存放更新前的记录
Update数据的时候就是先删除表记录,然后增加一条记录。这样在inserteddeleted表就都有update后的数据记录了。注意的是:触发器本身就是一个事务,所以在触发器里面可以对修改数据进行一些特殊的检查。如果不满足可以利用事务回滚,撤销操作。
INSERT触发器
sqlserver触发器
Update数据的时候就是先删除表记录,然后增加一条记录。这样在inserteddeleted表就都有update后的数据记录了。注意的是:触发器本身就是一个事务,所以在触发器里面可以对修改数据进行一些特殊的检查。如果不满足可以利用事务回滚,撤销操作。
INSERT触发器
sqlserver触发器
sqlserver触发器
sqlserver触发器
sqlserver触发器
sqlserver触发器

相关文章: