: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