问题描述:
在某环境中数据表存在多个触发器,数据的增删改是标准的每个表都有的触发器,此外还存在关于校验的触发器;起因是写完触发器后,有一次同事询问说触发器不起
作用了,没有提示错误,但是数据无法保存;我也有点莫名其妙,在查询分析器中执行直接就提示错误了,可在应用程序中无法提示错误。
同事提醒说需要执行一段设置触发器触发先后顺序的代码,查了一下为
sp_settriggerorder
;看了下帮助修改了一下即可。不过只看
SQLServer
联机帮助似乎是无法理解的,通过此次才了解该存储过程的意义。
顺便提一句,本环境是在SQLServer2000中,非2005中
以下为联机帮助中的释义。
指定第一个或最后一个激发的、与表关联的AFTER 语法 sp_settriggerorder |
做个简单测试
,新建
2
张表和
2
个触发器
CREATE TABLE TestA ( ); CREATE TABLE TestB ( ); ALTER AFTER INSERT,UPDATE AS SET NOCOUNT ON DECLARE @a VARCHAR(20) SELECT @a=a FROM INSERTED IF @a='A' OR @a='a' BEGIN END
ALTER 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= sp_settriggerorder @triggername= |