触发器 :new和 :old的使用

本文详细解释了在数据库触发器中如何使用OLD和NEW变量来获取更新前后行数据的变化情况。通过一个具体例子展示了这些变量在INSERT、UPDATE及DELETE操作中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

: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

 

转载于:https://www.cnblogs.com/rxhuiu/p/9116676.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值