触发器(一)-------触发器概述、递归触发器

什么是触发器?

触发器是一个在修改制定表中的数据时执行的存储过程。通常通过创建触发器来强制实现不同表中的逻辑相关数据的引用完整性或一致性。由于用户不能绕过触发器,所以可以用它来强制实施复杂的业务规则,以此确保数据的完整性。

触发器不同于存储过程。触发器主要是通过事件进行触发而被执行的,而存储过程可以通过存储过程的名字而被直接调用。当对某一表进行UPDATE、INSERT、DELETE这些操作时,SQL Server就会自动执行触发器所定义的SQL语句,从而确保对数据的处理必须符合由这些SQL语句所定义的规则。

为什么要使用触发器?

触发器自动执行,它们在表的数据作了任何修改(比如手工输入或者使用程序采集的操作)之后立即激活

触发器可以通过数据库中的相关表进行层叠更改。这比直接把代码写在前台的做法更安全合理。

触发器可以强制限制,这些限制比用CHECK约束所定义的更复杂。与CHECK约束不同的是,触发器可以应用其他表中的列。

触发器有哪些种类?

DML触发器

DML触发器是当数据库服务器中发生数据库操作语言(DML)事件时要执行的操作。通常所说的DML触发器主要包括三种:INSERT触发器、UPDATE触发器、DELETE触发器。DML触发器可以查询其他表,还可以包含复杂的T-SQL语句。将触发器和出发它的语句作为可在触发器内回滚的单个事务对待。如果检测到错误,则整个事务自动回滚。

DDL触发器

DDL触发器当服务器或者数据库中发生数据定义语言(DDL)事件时将被调用。如果要执行以下操作,可以使用DDL触发器:

要防止对数据库架构进行某些更改

希望数据库中发生某种情况以响应数据库架构中的更改

要记录数据库架构中的更改或者事件

递归触发器(慎重使用)

任何触发器都可以包含影响同一个表或另一个表的UPDATE、INSERT或DELETE语句。如果启用递归触发器选项,那么改变表中数据的触发器,通过递归执行就可以再次出发自己。在数据库创建时,默认情况下递归触发器选项是禁用的,但可以使用ALTER DATABASE语句来启用它。如下图:

递归触发器具有复杂特性,可以用它来解决诸如自引用关系这样的复杂关系。使用递归触发器时,需要考虑一下的事项和原则:

▶递归触发器很复杂,必须经过有条理的设计和全面的测试

▶在任意点的数据修改会出发一系列触发器。尽管提供处理复杂关系的能力,但是如果表要求以特定的顺序更新用户的表时,使用递归触发器就会产生问题

▶所有触发器一起构成一个大事务。任何触发器中的任何位置上的ROLLBACK命令都将取消所有数据输入。所有数据均被擦除,并且无任何数据将被放到表中

▶触发器最多只能递归16层,换句话说,如果递归链中的第16个触发器激活了第17个触发器,则结果与发布ROLLBACK命令一样,所有数据将被擦除

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章