以下的文章主要向大家讲述的是SQL server 数据库如何正确指定***个触发器与***一个触发器的实际操作方案,其具体的操作方案可以将和表相关联的 AFTER 触发器之一指定为每个 INSERT、DELETE 和 UPDATE 触发动作执行的***个或***一个 AFTER 触发器。
在***个和***一个触发器之间激发的 AFTER 触发器将按未定义的顺序执行。
若要指定 AFTER 触发器的顺序,请使用 sp_settriggerOrder 存储过程。可用的选项有:
***个
SQL server 数据库指定该触发器是为触发操作激发的***个 AFTER 触发器。
***一个
指定该触发器是为触发操作激发的***一个 AFTER 触发器。
无
指定触发器的激发没有特定的顺序。主要用于重新设置***个或***一个触发器。
以下是使用 sp_settriggerorder 的示例:
重要 ***个和***一个触发器必须是两个不同的触发器。
可能同时在表上定义了 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 将复制触发器更改为***触发器或无触发器,则订阅将不能正确工作。
【编辑推荐】
SQL:建立一个DML类UPDATE 触发器,
触发器一般用在check约束更加复杂的约束上面。 例如在执行update、insert、delete这些操作的时候,系统会自动调用执行该表上对应的触发器。 SQL Server 2005中触发器可以分为两类:DML触发器和DDL触发器,其中DDL触发器它们会影响多种数据定义语言语句而激发,这些语句有create、alter、drop语句。
关于Sql Server里面设置触发器
可以使用ddl触发器,下面的网址介绍的很详细了,请参照:补充:CREATE TRIGGER TEST_DDL_TRIGGER ON DATABASE FORALTER_TABLE ASBEGINRAISERROR(这个数据库不允许alter table操作!, 16, 1)ROLLBACKEND*************************---以上,希望对你有所帮助。
SQl中怎么样创建触发器?
触发器是一种特殊类型的存储过程。 主要是通过事件触发而被执行。 创建触发器的格式举例:(删除)create trigger delete_triggeron employeefor deleteas delete p_order from p_order inner join deleted on p_order.雇员ID=deleted.雇员ID可以创建 删除,更新,插入 事件的 触发器
发表评论