以下的文章主要向大家讲述的是SQL server 数据库如何正确指定***个触发器与***一个触发器的实际操作方案,其具体的操作方案可以将和表相关联的 AFTER 触发器之一指定为每个 INSERT、DELETE 和 UPDATE 触发动作执行的***个或***一个 AFTER 触发器。
在***个和***一个触发器之间激发的 AFTER 触发器将按未定义的顺序执行。
若要指定 AFTER 触发器的顺序,请使用 sp_settriggerorder 存储过程。可用的选项有:
***个
SQL server 数据库指定该触发器是为触发操作激发的***个 AFTER 触发器。
***一个
指定该触发器是为触发操作激发的***一个 AFTER 触发器。
无
指定触发器的激发没有特定的顺序。主要用于重新设置***个或***一个触发器。
以下是使用 sp_settriggerorder 的示例:
- sp_settriggerorder @triggername = 'MyTrigger', @order = 'first', @stmttype = 'UPDATE'
重要 ***个和***一个触发器必须是两个不同的触发器。
可能同时在表上定义了 INSERT、UPDATE 和 DELETE 触发器。每种语句类型可能都有自己的***个和***一个触发器,但它们不能是相同的触发器。
如果为某个表定义的***个或***一个触发器不包括触发操作,如 FOR UPDATE、FOR DELETE 或 FOR INSERT,则缺少的操作将没有***个或***一个触发器。
不能将 INSTEAD OF 触发器SQL server 数据库指定为***个或***一个触发器。在对基础表进行更新前激发 INSTEAD OF 触发器。然而,如果由 INSTEAD OF 触发器对基础表进行更新,则这些更新将发生于在表上定义触发器(包括***个触发器)之后。
例如,如果视图上的 INSTEAD OF 触发器更新基表并且该基表包含三个触发器,则该三个触发器在 INSTEAD OF 触发器插入数据之前激发。有关更多信息,请参见SQL server 数据库指定触发器何时激发。
如果 ALTER TRIGGER 语句更改了***个或***一个触发器,则将除去 First 或 Last 特性,并且顺序值将设置为 None;必须用 sp_settriggerorder 重置此顺序。
OBJECTPROPERTY 函数使用属性 ExecIsFirstTrigger 和 ExecIsLastTrigger 报告触发器的顺序是***个还是***一个。
复制将为本身是即时更新订户或排队更新订户的任何表自动生成***个触发器。复制要求它的触发器是***个触发器。如果尝试使具有***个触发器的表成为即时更新订户或排队更新订户,复制将引发错误。如果使表成为即时更新订户或排队更新订户之后使用户定义触发器成为***个触发器,则 sp_settriggerorder 会返回一个错误。
如果在复制触发器上使用 ALTER,或使用 sp_settriggerorder 将复制触发器更改为***触发器或无触发器,则订阅将不能正确工作。
【编辑推荐】