觸發器 :new和 :old的使用


:new --為一個引用最新的列值;
:old --為一個引用以前的列值;

這兩個變量只有在使用了關鍵字 "FOR EACH ROW"時才存在,且update語句兩個都有,而insert只有:new ,delete 只有:old;

特性

INSERT

UPDATE

DELETE

OLD

NULL

實際值

實際值

NEW

實際值

實際值

NULL

實例:

1 create or replace trigger TRI_PrintTest 2 before delete or insert or update on TEST_EXAM  --觸發事件 
3 for each row                  -- 每修改一行都需要調用此過程 
4 begin  
5      dbms_output.put_line(:new.IDNEW);     --IDNEW字段更新后的值 
6      dbms_output.put_line(:old.IDNEW);       --IDNEW字段更新前的值 
7 end;  

原IDNEW字段是1時,

使用

update TEST_EXAM set IDNEW=5 where SN='5454';

則打印結果為:

5
1

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM