[SQL Server] 多触发器执行问题
2010-03-20 00:13
274 查看
问题描述:
在某环境中数据表存在多个触发器,数据的增删改是标准的每个表都有的触发器,此外还存在关于校验的触发器;起因是写完触发器后,有一次同事询问说触发器不起作用了,没有提示错误,但是数据无法保存;我也有点莫名其妙,在查询分析器中执行直接就提示错误了,可在应用程序中无法提示错误。
同事提醒说需要执行一段设置触发器触发先后顺序的代码,查了一下为 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';
-------------------------------------------------------------------------------------
在某环境中数据表存在多个触发器,数据的增删改是标准的每个表都有的触发器,此外还存在关于校验的触发器;起因是写完触发器后,有一次同事询问说触发器不起作用了,没有提示错误,但是数据无法保存;我也有点莫名其妙,在查询分析器中执行直接就提示错误了,可在应用程序中无法提示错误。
同事提醒说需要执行一段设置触发器触发先后顺序的代码,查了一下为 sp_settriggerorder ;看了下帮助修改了一下即可。不过只看 SQLServer 联机帮助似乎是无法理解的,通过此次才了解该存储过程的意义。
顺便提一句,本环境是在SQLServer2000中,非2005中
以下为联机帮助中的释义。
sp_settriggerorder 指定第一个或最后一个激发的、与表关联的AFTER 触发器。在第一个和最后一个触发器之间激发的AFTER 触发器将按未定义的顺序执行。 语法 sp_settriggerorder [@triggername = ] 'triggername', [@order = ]' value ', [@stmttype = ]' statement_type '
做个简单测试 ,新建 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';
-------------------------------------------------------------------------------------
相关文章推荐
- sql server中高并发情况下 同时执行select和update语句死锁问题 (二)
- Sql 2005安装问题,因为WMI配置,无法执行Sql Server 系统配置检查器的解决办法!
- 关于触发器在行级和语句级的执行顺序问题
- sql server中高并发情况下 同时执行select和update语句死锁问题 (二)
- SQL Server用触发器强制执行业务规则
- SQL Server触发器问题总结
- sql server中高并发情况下同时执行select和update语句死锁问题(二)
- sql server中同时执行select和update语句死锁问题
- sql server中高并发情况下 同时执行select和update语句死锁问题 (二)
- SQL Server 2005 重装 执行向导安装期间出错 问题解决
- SQL Server技术问题之触发器优缺点
- sql server执行存储过程慢的问题
- SQL Server使用代理服务执行job时报错问题解决了
- sql server在高并发状态下同时执行查询与更新操作时的死锁问题
- oracle创建触发器的脚本在sqlplus中执行不了问题的解决
- 关于mysql中触发器执行动态sql的问题
- sql server中同时执行select和update语句死锁问题
- 腾讯云图片鉴黄集成到C# SQL Server 怎么在分页获取数据的同时获取到总记录数 sqlserver 操作数据表语句模板 .NET MVC后台发送post请求 百度api查询多个地址的经纬度的问题 try{}里有一个 return 语句,那么紧跟在这个 try 后的 finally {}里的 code 会 不会被执行,什么时候被执行,在 return 前还是后? js获取某个日期
- [sql server发布订阅]after触发器执行失败造成复制不成功
- SQL server无法执行查询,因为一些文件丢失或未注册等问题的解决