Chinaunix首页 | 论坛 | 博客
  • 博客访问: 167415
  • 博文数量: 103
  • 博客积分: 2251
  • 博客等级: 大尉
  • 技术积分: 1095
  • 用 户 组: 普通用户
  • 注册时间: 2007-04-03 11:15
文章分类

全部博文(103)

文章存档

2011年(103)

分类: 数据库开发技术

2011-05-04 23:03:13

问题描述:

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

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

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

sp_settriggerorder

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

语法

sp_settriggerorder[@triggername =]'triggername'ITPUB个人空间*d9Z xP'S7Y
    ,
[@order =]'value'ITPUB个人空间A0X'E&|jM"DcQ_
    ,
[@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', @order='first', @stmttype = 'INSERT';

 

阅读(381) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~