加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

关于SQLServer2005的学习笔记——多触发器执行问题

发布时间:2020-12-12 15:26:05 所属栏目:MsSql教程 来源:网络整理
导读:问题描述: 在某环境中数据表存在多个触发器,数据的增删改是标准的每个表都有的触发器,此外还存在关于校验的触发器;起因是写完触发器后,有一次同事询问说触发器不起 作用了,没有提示错误,但是数据无法保存;我也有点莫名其妙,在查询分析器中执行直接

sp_settriggerorder

指定第一个或最后一个激发的、与表关联的AFTER 触发器。在第一个和最后一个触发器之间激发的AFTER 触发器将按未定义的顺序执行。

语法

sp_settriggerorder [@triggername = ]' triggername 'ITPUB个人空间9b6L.E#z2O
????,
[@order = ]' value 'ITPUB个人空间./8z_ UL#O
????,
[@stmttype = ]' statement_type '

?

做个简单测试 ,新建 2 张表和 2 个触发器

CREATE TABLE TestA

(

? a VARCHAR(20)

);

CREATE TABLE TestB

(

? a VARCHAR(20)

);

ALTER? TRIGGER [Tri_Test1] ON TestA

AFTER INSERT,UPDATE

AS

SET NOCOUNT ON

DECLARE @a VARCHAR(20)

SELECT @a=a FROM INSERTED

IF @a='A' OR @a='a'

BEGIN

???????? RAISERROR ( ' 该条记有问题 , 不能重复保存! ',16,1 )

???????? ROLLBACK TRAN

???????? RETURN

END

?

ALTER? TRIGGER [Tri_Syn_Test1] ON TestA

AFTER INSERT,UPDATE

AS

SET NOCOUNT ON

INSERT INTO TestB SELECT a FROM inserted

COMMIT;

?

?

TestA 表插入一个 A 值,系统提示该条记有问题 , 不能重复保存!

但是假如在应用程序中的话,很可能系统不会提示错误,但是保存失败,原因是 Tri_Syn_Test1 一定会执行成功,而应用程序捕获不到后面触发器中的错误了。

这个时候需要将 Order 设置为 first

INSERT INTO TestA VALUES('A')

sp_settriggerorder @triggername= '30SJK_TEST_U.Tri_Test1',@order='first',@stmttype = 'UPDATE';

sp_settriggerorder @triggername= '30SJK_TEST_U.Tri_Test1',@stmttype = 'INSERT';

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

问题描述:

在某环境中数据表存在多个触发器,数据的增删改是标准的每个表都有的触发器,此外还存在关于校验的触发器;起因是写完触发器后,有一次同事询问说触发器不起 作用了,没有提示错误,但是数据无法保存;我也有点莫名其妙,在查询分析器中执行直接就提示错误了,可在应用程序中无法提示错误。

同事提醒说需要执行一段设置触发器触发先后顺序的代码,查了一下为 sp_settriggerorder ;看了下帮助修改了一下即可。不过只看 SQLServer 联机帮助似乎是无法理解的,通过此次才了解该存储过程的意义。

顺便提一句,本环境是在SQLServer2000中,非2005中

以下为联机帮助中的释义。

    推荐文章
      热点阅读