[SQL Server] 多触发器执行问题

问题描述:

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

 

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

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


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

 

 

 

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

-------------------------------------------------------------------------------------

create table testa

(  a varchar(20));

 

create table testb

(  a varchar(20) );

 

create 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

 

create 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', @order='first', @stmttype = 'insert';

-------------------------------------------------------------------------------------

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值