触发器简介:
触发器是一种特殊的存储过程,它的执行不是由程序调用,也不是手动执行,而是由事件来触发。触发器是当对某一个表进行操作。例如:update、insert、delete这些操作的时候,系统会自动调用执行该表上对应的触发器。
触发器分类:
1、DML( 数据操纵语言 Data Manipulation Language)触发器:是指触发器在数据库中发生 DML 事件时将启用。DML事件是指在表或视图中对数据进行的 insert、update、delete 操作的语句。
2、DDL(数据定义语言 Data Definition Language)触发器:是指当服务器或数据库中发生 DDL 事件时将启用。DDL事件是指在表或索引中的 create、alter、drop 操作语句。
3、登陆触发器:是指当用户登录 SQL SERVER 实例建立会话时触发。如果身份验证失败,登录触发器不会触发。
其中 DML 触发器比较常用,根据 DML 触发器触发的方式不同又分为以下两种情况:
after 触发器(之后触发):其中 after 触发器要求只有执行 insert、update、delete 某一操作之后触发器才会被触发,且只能定义在表上。
instead of 触发器 (之前触发):instead of 触发器并不执行其定义的操作(insert、update、delete)而仅是执行触发器本身。可以在表或视图上定义 instead of 触发器。
DML 触发器有两个特殊的表:插入表(instered)和删除表(deleted),这两张表是逻辑表。这两个表是建立在数据库服务器的内存中,而且两张表的都是只读的。这两张表的结构和触发器所在的数据表的结构是一样的。当触发器完成工作后,这两张表就会被删除。Inserted 表的数据是插入或是修改后的数据,而 deleted 表的数据是更新前的或是已删除的数据。
AFTER 触发器语法:
1 CREATE [ OR ALTER ] TRIGGER [ schema_name . ]trigger_name 2 ON { table } 3 [ WITH[ ,...n ] ] 4 { FOR | AFTER } 5 { [ INSERT ] [ , ] [ UPDATE ] [ , ] [ DELETE ] } 6 AS { sql_statement [ ; ] [ ,...n ] } 7 8 ::= 9 [ NATIVE_COMPILATION ] 10 [ SCHEMABINDING ] 11 [ EXECUTE AS Clause ]
INSTEAD OF 触发器语法:
1 CREATE [ OR ALTER ] TRIGGER [ schema_name . ]trigger_name 2 ON { table | view } 3 [ WITH[ ,...n ] ] 4 { FOR | AFTER | INSTEAD OF } 5 { [ INSERT ] [ , ] [ UPDATE ] [ , ] [ DELETE ] } 6 [ WITH APPEND ] 7 [ NOT FOR REPLICATION ] 8 AS { sql_statement [ ; ] [ ,...n ] | EXTERNAL NAME } 9 10 ::= 11 [ ENCRYPTION ] 12 [ EXECUTE AS Clause ] 13 14 ::= 15 assembly_name.class_name.method_name
DDL 触发器语法:
1 CREATE [ OR ALTER ] TRIGGER trigger_name 2 ON { ALL SERVER | DATABASE } 3 [ WITH[ ,...n ] ] 4 { FOR | AFTER } { event_type | event_group } [ ,...n ] 5 AS { sql_statement [ ; ] [ ,...n ] | EXTERNAL NAME < method specifier > [ ; ] } 6 7 ::= 8 [ ENCRYPTION ] 9 [ EXECUTE AS Clause ]
登陆触发器语法:
1 CREATE [ OR ALTER ] TRIGGER trigger_name 2 ON ALL SERVER 3 [ WITH[ ,...n ] ] 4 { FOR| AFTER } LOGON 5 AS { sql_statement [ ; ] [ ,...n ] | EXTERNAL NAME < method specifier > [ ; ] } 6 7 ::= 8 [ ENCRYPTION ] 9 [ EXECUTE AS Clause ]