欢迎光临
我们一直在努力

Oracle触发器修改同一表不同字段

比如说当表A的一个insert,update的操作,然后自动把表A的相关字段update为一个值,但是这样就会造成死循环,如何只让触发器只执行一次。

create trigger biufer_employees_department_id
      before insert or update
              of department_id
              on employees
      referencing old as old_value
                      new as new_value
      for each row
      when (new_value.department_id <>80 )
begin
      :new_value.commission_pct :=0;
end;

    这种自身触发只能修改 :new_value.commission_pct,我如果想修改某特定行的数据,需要加限制条件的,如果处理。加WHERE…?不太明白楼主想要表达什么意思
如果要修改当前记录的值,条件在when里面控制就好了
如果是要修改非当前记录的其他特定记录的值,要改成表级触发器或者使用自治事务了如果不是要修改本行,改成表级触发器。<
<
这样在触发器中操作同一个触发表的表是不是叫“变异表”哟!以前好像在那里看见过关于变异表的概验。要用自治事物。
pragma autonomous_transaction;<
不能改成表触发器,因为我还得使用OLD NEW。我使用了自治事务,但是编译不过去。提示pragma autonomous_transaction cannot be declared here CREATE OR REPLACE TRIGGER trig_ac30_AAE008
  AFTER insert or update of  AAE008
  ON AAE008_UPDATE
  for each row
when (OLD.AAE008 <> NEW.AAE008)
BEGIN
declare
pragma autonomous_transaction;

赞(0) 打赏
未经允许不得转载:蒲公英博客 » Oracle触发器修改同一表不同字段
分享到: 更多 (0)

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

大前端WP主题 更专业 更方便

联系我们联系我们

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏