1.除了DML Trigger外,SQL Server 2005新增加了DDL Trigger
2.在使用Trigger时,要综合考虑性能
3.Trigger不能代替Constraint
4.能用存储过程,就尽量不要用触发器
5.非Log的操作不支持触发器
6.DML触发器分为:after trigger(用于表),instead of trigger(用于表和视图)
7.在DML触发器定义中,可声明触发器是否适用于数据复制
8.INSTEAD OF 触发器用来代替通常的触发动作,即当对表进行INSERT、UPDATE 或 DELETE 操作时,系统不是直接对表执行这些操作,而是把操作内容交给触发器,让触发器检查所进行的操作是否正确如正确才进行相应的操作。因此,INSTEAD OF 触发器的动作要早于表的约束处理 每一个表上只能创建一个 INSTEAD OF 触发器,但可以创建多个 AFTER 触发器
9.sys.triggers查看触发器原数据信息
10.DDL触发器,分为数据库层面的和服务器场面的,前者作为对象存在于数据库中,后者存在于master数据库中
11.当导入或者恢复数据时,可以考虑disable触发器,使用disable trigger命令
12.通过EXEC sp_configure 'nested triggers', 0设置触发器嵌套层数,默认最大32
13.设置RECURSIVE_TRIGGERS选项控制触发器是否支持迭代
14.使用sp_settriggerorder设置触发器触发顺序
2.在使用Trigger时,要综合考虑性能
3.Trigger不能代替Constraint
4.能用存储过程,就尽量不要用触发器
5.非Log的操作不支持触发器
6.DML触发器分为:after trigger(用于表),instead of trigger(用于表和视图)
7.在DML触发器定义中,可声明触发器是否适用于数据复制
8.INSTEAD OF 触发器用来代替通常的触发动作,即当对表进行INSERT、UPDATE 或 DELETE 操作时,系统不是直接对表执行这些操作,而是把操作内容交给触发器,让触发器检查所进行的操作是否正确如正确才进行相应的操作。因此,INSTEAD OF 触发器的动作要早于表的约束处理 每一个表上只能创建一个 INSTEAD OF 触发器,但可以创建多个 AFTER 触发器
9.sys.triggers查看触发器原数据信息
10.DDL触发器,分为数据库层面的和服务器场面的,前者作为对象存在于数据库中,后者存在于master数据库中
11.当导入或者恢复数据时,可以考虑disable触发器,使用disable trigger命令
12.通过EXEC sp_configure 'nested triggers', 0设置触发器嵌套层数,默认最大32
13.设置RECURSIVE_TRIGGERS选项控制触发器是否支持迭代
14.使用sp_settriggerorder设置触发器触发顺序