首页 > 数据库技术 > 详细

ORACLE触发器判断是否更新了某个字段

时间:2014-03-07 15:28:50      阅读:709      评论:0      收藏:0      [点我收藏+]

       今天遇到一个有意思的小问题,一同事有这样一个需求:在更新表T时,如果只是更新字段C,那么不希望触发该该表的触发器去处理业务逻辑。即想在触发器中做出判断:如果更新了字段C,那么跳出触发器,不处理业务逻辑,如果是更新其它字段,那么让触发器去处理业务逻辑。
他是这样做的

   

   1: if :NEW.C != :OLD.C then
   2:      return;
   3: end if;
但是这样有一个问题:更新不一定值有变化.当更新的值有变化时,它很好的实现了业务逻辑,但是如果更新的值没有变化,那么这段代码就会失效了。

其实这个只需要使用条件谓词 DELETING即可解决,当触发事件是UPDATE时,如果修改了COLUMN_X时,则UPDATING(COLUMN_X)则为TRUE,否则为FALSE,所以上面代码改为下面代码即可实现其业务需求:


   1: if updating(‘C‘) then
   2:    return;
   3: end if;

ORACLE触发器判断是否更新了某个字段,布布扣,bubuko.com

ORACLE触发器判断是否更新了某个字段

原文:http://www.cnblogs.com/kerrycode/p/3584865.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!