爱是王道 发表于 2018-10-23 09:08:16

13. SQL -- 多触发器执行问题

  http://baoqiangwang.blog.51cto.com/1554549/310455
  问题描述
  在某环境中数据表存在多个触发器数据的增删改是标准的每个表都有的触发器此外还存在关于校验的触发器起因是写完触发器后有一次同事询问说触发器不起作用了没有提示错误但是数据无法保存我也有点莫名其妙在查询分析器中执行直接就提示错误了可在应用程序中无法提示错误。
  同事提醒说需要执行一段设置触发器触发先后顺序的代码查了一下为 sp_settriggerorder 看了下帮助修改了一下即可。不过只看 SQLServer 联机帮助似乎是无法理解的通过此次才了解该存储过程的意义。
  顺便提一句本环境是在SQLServer2000中非2005中
  以下为联机帮助中的释义。
  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)
  );
  ALTERTRIGGER 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
  ALTERTRIGGER 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';

页: [1]
查看完整版本: 13. SQL -- 多触发器执行问题