SQL server 数据库指定第一个与最后一个触发器的方案

数据库 SQL Server
我们今天主要向大家介绍的是SQL server 数据库如何正确指定第一个触发器与最后一个触发器的实际操作方案,以下就是文章的主要内容描述。

以下的文章主要向大家讲述的是SQL server 数据库如何正确指定***个触发器与***一个触发器的实际操作方案,其具体的操作方案可以将和表相关联的 AFTER 触发器之一指定为每个 INSERT、DELETE 和 UPDATE 触发动作执行的***个或***一个 AFTER 触发器。

在***个和***一个触发器之间激发的 AFTER 触发器将按未定义的顺序执行。

 

若要指定 AFTER 触发器的顺序,请使用 sp_settriggerorder 存储过程。可用的选项有:

 

 

***个

 

SQL server 数据库指定该触发器是为触发操作激发的***个 AFTER 触发器。

 

***一个

 

指定该触发器是为触发操作激发的***一个 AFTER 触发器。

 

 

指定触发器的激发没有特定的顺序。主要用于重新设置***个或***一个触发器。

 

以下是使用 sp_settriggerorder 的示例:

 

 

 

  1. 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 将复制触发器更改为***触发器或无触发器,则订阅将不能正确工作。

 

【编辑推荐】

  1. SQL Server备份文件中对现存数据库的导入
  2. 用SQL Server DBCC 避免堵塞的实际操作步骤
  3. SQL Server 2000重建索引的实际操作流程
  4. 改善SQL Server安全规划的6步骤
  5. 通过SQL Server 2000日志转移来实现高可用性
责任编辑:佚名 来源: 互联网
相关推荐

2011-08-15 11:24:46

SQL Server事务

2010-03-15 10:37:46

Pthon脚本

2011-04-06 11:34:52

SQL Server数查询优化

2011-04-06 15:36:56

SQL Server数

2021-11-02 14:54:41

排序数组元素

2011-07-25 09:32:28

2021-12-13 11:31:36

排序数组数据结构算法

2019-10-22 07:50:45

SqlServer数据库触发器

2010-06-28 09:53:11

SQL Server数

2011-08-04 18:55:53

SQL Server 用户sa登录失败

2020-11-13 07:08:51

Spring Boot应用Spring

2011-08-03 10:40:17

SQL Server数全文检索

2011-04-01 16:35:09

SQL Server数触发器

2010-06-30 09:36:25

SQL Server

2019-12-02 11:13:38

数据库触发器SQLServer

2013-12-19 09:46:04

垃圾收集器

2011-08-02 13:26:38

JavaBeanSQL Server

2022-10-17 10:28:05

Web 组件代码

2013-10-30 22:10:28

Clouda程序

2023-09-21 22:43:17

Django框架
点赞
收藏

51CTO技术栈公众号