oracle 触发器before和after数据区别

WBOY
リリース: 2016-06-07 15:20:08
オリジナル
2347 人が閲覧しました

oracle触发器中,一旦数据被插入了,不能使用after insert去更改已经插入的,已经存在,更改会使触发器不执行。 如果想将查询出来的数据插入到数据库中,应该先拼接好,然后before命令会将数据插入到数据库中。 create or replace trigger test before inser

oracle触发器中,一旦数据被插入了,不能使用after insert去更改已经插入的值,值已经存在,更改会使触发器不执行。

如果想将查询出来的数据插入到数据库中,应该先拼接好,然后before命令会将数据插入到数据库中。


create or replace trigger "test"

before insert on mh_task for each row


declare
      PRAGMA            AUTONOMOUS_TRANSACTION;
      task_id           mh_task.id%type ;
      hdl_empid         mh_task.hdl_empid%type ;
      xzagent           xz_agent.userid%type :=0;
      mh_buss_name      mh_task.buss_name%type;
      mh_buss_type      mh_task.buss_type%type;


begin
      task_id   := :new.id ;
      hdl_empid := :new.hdl_empid ;
      mh_buss_name := :new.buss_name;
      mh_buss_type := :new.buss_type;


begin
     if mh_buss_name is not null then
       select distinct userid into xzagent from xz_agent  where agent = hdl_empid and  branch like '%'||mh_buss_name||'%' and rownum = 1;
     end if;


      if  xzagent != 0 then
          --update mh_task set agent = xzagent where id = task_id ;
          :new.agent := xzagent;
      end if ;
      commit;
exception                          --cx 添加异常处理
      when NO_DATA_FOUND then      --
           null;
end;                              --


end  test;
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!