最新活动:买一送一!升级会员,最高返 500 抵扣券!>>>

\"OLD和NEW关键字使我们能够访问受触发器影响的行中的列。\"

\

正如我们所知,在触发器定义中,我们可以引用正在插入、更新或删除的行的列。以下是OLD和NEW关键字使我们能够访问列的方式:

  • 我们必须在列名前加上一个OLD限定符,以引用原始行中的值。

  • 我们必须在列名前加上NEW限定符,以引用新行中的值。

现在,必须适当地使用OLD和NEW,因为触发事件

确定哪些是允许的 −

  • 在INSERT触发器中,NEW.column_name表示要插入到新行中的列值。这里不允许使用OLD。

  • 在DELETE触发器中,OLD.column_name表示要删除的行中某列的值。在这里,NEW是不允许的。

  • 在UPDATE触发器中,OLD.column_name和NEW.column_name分别指的是在行更新之前和之后的行中列的值。

换句话说,我们可以说OLD必须以只读方式使用,而NEW可以用于读取或更改列的值。

在触发器中使用关键字OLD

以下是DELETE触发器示例,展示了OLD的使用方式 −

mysql> CREATE TRIGGER studentinfo_after_delete
   -> AFTER DELETE
   -> ON student_info
   -> FOR EACH ROW FOLLOWS
   -> BEGIN
   -> DECLARE vuser varchar(30);
   -> SELECT USER() into vuser;
   -> INSERT INTO student_info_deleted(id,deleted_date,deleted_by) VALUES(OLD.id,SYSDATE(),vuser);
   -> END; //
Query OK, 0 rows affected (0.25 sec)
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

给TA打赏
共{{data.count}}人
人已打赏
数据库

oracle数据库监听服务怎么是手动

2024-5-5 13:35:01

数据库

深入剖析MongoDB的复制集与分片集群的搭建与优化

2024-5-5 13:47:48

!
你也想出现在这里?立即 联系我们吧!
信息
个人中心
购物车
优惠劵
今日签到
搜索