触发器是一种特殊的存储过程,它不需要用户去用过事件去主动触发,而是在事件进行出发而自动调用的。
触发器分DDL和DML两种。
DDL是一种为了响应各种数据定义语言 (DDL) 事件而激发的触发器。主要是以DROP、ALTER、CREATE这种关键字来激发的。
DML是一种为了响应各种数据操纵语言 (DML) 事件而激发的触发器。主要是以INSERT、DELETE、UPDATE这种关键字来激发的。
DML触发器分为AFTER和INSTEAD OF两种:
AFTER触发器只有被INSERT触发器、UPDATE触发器、DELETE触发器之后触发某一触发器触法之后才能触发。且只能定义在表上。
instead of触发器表示并不执行其定义的操作(insert、update、delete)而仅是执行触发器本身。既可以在表上定义instead of触发器,也可以在视图上定义。
触发器由两个名叫INSERT和DELETE的虚表,有系统在内存中创建者两张表,不会存储在数据库中。而且两张表的都是只读的,只能读取数据而不能修改数据。这两张表的结果总是与被改触发器应用的表的结构相同。当触发器完成工作后,这两张表就会被删除。
对表的操作 |
Inserted逻辑表
|
Deleted逻辑表
|
增加记录(insert)
|
存放增加的记录 |
无 |
删除记录(delete)
|
无 |
存放被删除的记录 |
修改记录(update)
|
存放更新后的记录 |
存放更新前的记录 |
Update数据的时候就是先删除表记录,然后增加一条记录。这样在inserted和deleted表就都有update后的数据记录了。注意的是:触发器本身就是一个事务,所以在触发器里面可以对修改数据进行一些特殊的检查。如果不满足可以利用事务回滚,撤销操作。
INSERT触发器
Update数据的时候就是先删除表记录,然后增加一条记录。这样在inserted和deleted表就都有update后的数据记录了。注意的是:触发器本身就是一个事务,所以在触发器里面可以对修改数据进行一些特殊的检查。如果不满足可以利用事务回滚,撤销操作。
INSERT触发器