一、触发器的概念

       SQL Server提供两种主要机制来强制使用业务规则和数据完整性,即约束和触发器。

       触发器是一种特殊类型的存储过程,当指定表中的数据发生变化时触发器自动生效。它与表紧密相连,可以看作是表定义的一部分。触发器不能通过名称被直接调用,更不允许设置参数。

       在 SQL Server中一张表可以有多个触发器。用户可以使用 INSERT、 UPDATE或 DELETE语句对触发器进行设置,也可以对一张表上的特定操作设置多个触发器。触发器可以包含复杂的 Transact-SQL语句。不论触发器所进行的操作有多复杂,触发器都只作为一个独立的单元被执行,被看作是一个事务。如果在执行触发器的过程中发生了错误,则整个事务将会自动回滚。 

 二、触发器的优点

      触发器的优点表现在以下几个方面:

  1. 触发器自动执行,对表中的数据进行修改后,触发器立即被激活。
  2. 为了实现复杂的数据库更新操作,触发器可以调用一个或多个存储过程,甚至可以通过调用外部过程(不是数据库管理系统本身)完成相应的操作。
  3. 触发器能够实现比 CHECK约束更为复杂的数据完整性约束。在数据库中,为了实现数据完整性约束,可以使用 CHECK约束或触发器。 CHECK约束不允许引用其他表中的列来完成检查工作而触发器可以引用其他表中的列。触发器更适合在大型数据库管理系统中用来约束数据的完整性
  4. 触发器可以检测数据库内的操作,从而取消了数据库未经许可的更新操作,使数据库修改、更新操作更安全,数据库的运行也更稳定
  5. 触发器能够对数据库中的相关表实现级联更改。触发器是基于一个表创建的,但是可以针对多个表进行操作,实现数据库中相关表的级联更改。
  6. 一个表中可以同时存在3个不同操作的触发器( INSERT、 UPDATE和 DELETE)。 

 三、触发器的种类

1.DML触发器 

         当数据库中发生数据操作语言(DML)事件时将调用DML触发器。DML事件包括在指定表或视图中修改数据的 INSERT语句、 UPDATE语句或 DELETE语句。DML触发器可以查询其他表,还可以 包含复杂的 Transact-SQL语句。
用户可以设计以下类型的DML触发器。

  • AFTER(FOR)触发器:在执行了 INSERT、 UPDATE或 DELETE语句操作之后执行 AFTER触发器。
  • INSTEAD OF触发器:执行 INSTEAD OF触发器代替通常的触发动作。还可为带有一个或多个基表的视图定义 INSTEAD OF触发器,而这些触发器能够扩展视图可支持的更新类型。INSTEAD OF触发器只能存在一个,例:INSTEAD OF UPDATE不能存在两个。
  • CLR触发器:CLR触发器可以是 AFTER触发器或 INSTEAD OF触发器。CLR触发器还可以是DDL触发器。CLR触发器将执行在托管代码(在 NET Framework中创建并在 SQL Server中上载的程序集的成员)中编写的方法,而不用执行 Transact-SQL存储过程。

PS: (1)AFTER先执行增删改操作,再执行触发器操作; INSTEAD OF直接只执行触发器里的。

       (2)触发器会产生两张表inserted(语句执行后的受影响的数据表),deleted(受影响语句执行前的数据表),这两张表会                    保存中间过度数据,存在内存里,等触发器执行完后就释放。这两张表都只是缓存,不表示实际的数据表。

2.DDL触发器

        DDL触发器用于响应各种数据定义语言(DDL)事件。这些事件主要对应于 Transact-SQL CREATE 、ALTER和DROP语句,以及执行类似DDL操作的某些系统存储过程 。

3.登录触发器 

       登录触发器在遇到 LOGON事件时触发。 LOGON事件是在建立用户会话时引发的。触发器可以由Transact-SQL语句直接创建,也可以由程序集方法创建,这些方法是在 Microsoft. NET Framework公共语言运行时(CLR)中创建并上载到 SQL Server实例的。 SQL Server允许为任何特定语句创建多个触发器 。