2024年4月27日发(作者:)

1. 触发器的概念

触发器是一种特殊类型的存储过程。当表中数据被修改时,SQL Server将自动执行触发

器。使用触发器可以实施较为复杂的数据完整性约束。

在SQL Server中,数据库的表之间可以声明参照完整性约束,即主键(PRIMARYKEY)

和外键(FOREIGNKEY)约束。在同一数据库中的简单参照完整性通常由主键和外键约束来

实现。但是,由于声明参照完整性约束不能参照其他数据库中的对象,而对于数据库之间的

参照完整性约束就只有通过触发器来实现。引用完整性约束与触发器,对数据操作构成了双

重的有效性约束。

当对一个同时具有约束和触发器的表进行数据修改操作时,SQL Server将先进行约束检

查,然后再执行触发器检查。如果这些语句的操作符合约束条件,系统将完成数据操作,然

后再激活触发器;如果该语句未能通过约束检查,将不执行该数据操作语句,也就不可能激

活触发器。如果某语句通过了约束检查而未能通过触发器检查,触发器也将取消该语句已经

执行完毕的操作。

触发器的主要优点是:

任何一种对触发器表中数据进行修改的操作(包括操作人员录入数据或其他应用程序的

修改)都能自动激活触发器,从而触发对这些操作进行的完整性检查。

(1)触发器能够实施的检查和操作比主键和外键约束、CHECK约束和规则对象等更为复

杂。例如,CHECK约束只能根据一个逻辑表达式或同一个表中其他列值来检查指定列值的

有效性,而使用触发器时则可以参照其他表中的列值。

(2)触发器建立在表一级,它与特定的数据修改事件相对应。而INSERT、UPDATE和

DELETE三种操作都可能导致数据的修改,所以SQL Server中的触发器可分为 INSERT触

发器、UPDATE触发器和DELETE触发器三种。而且SQL Server 2000版本中允许对同一数

据对象修改事件、同一个数据操作定义多个触发器,这在SQLServer7.0以前的版本中是被

禁止的。

触发器只能由数据库所有者创建。因为当为某一个表或表的列、行创建触发器时,表的

访问方式及其对象之间的关系也随之改变了。也就是说,触发器的创建变动了数据库模式,

所以创建触发器的权利应该保留给数据库的所有者,以防止普通用户无意间修改了系统格

局。

2. 触发器的创建

触发器(TRIGGER)由Transact-SQL中的CREATE TRIGGER语句创建,语句中应

该包含所定义触发器基于的表、激活触发器的数据操作事件名称以及触发器所要执行的相应

操作。CREATE TRIGGER语句不允许带参数,也不允许被直接调用,而只能由系统自动激

活。CREATE TRIGGER定义触发器有两种格式。第一种格式定义触发器的触发事件为

INSERT、UPDATE、DELETE等操作。其语法格式如下:

显示代码打印

01 CREATE TRIGGER[owner,]trigger_name

02

03 On[owner,]table_name

04

05 [WITH ENCRYPTION]

06

07 {

08

09 FOR{[INSERT][,UPDATE][,DELETE]}

10

11 [NOT FORREPLICATION]

12

13 AS sql_statements

14

15 }

在上述语句中:

① trigger_name:为创建的触发器名称,它必须遵守SQL Server的命名规则,而且同一

个数据库中不允许出现触发器名称相同的情况。

② table_name:为该语句中定义的触发器所基于的表,也称为触发表。

⑧ WITH ENCRYPTION选项:SQL Server将触发器的定义文本保存在系统分类表

syscomments中,选用此项要求SQL Server对该触发器定义文本进行加密存储,以防止第三

方用户从syscomments表中读取该触发器定义文本的内容。

④ NOT FOR REPLICATION选项:说明在复制过程中出现修改触发表数据时,触发器

不被激活。