如何使用 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)
在触发器中使用 NEW 关键字
以下 INSERT 触发器的示例展示了 NEW 的用法:
mysql> Create Trigger before_inser_studentage BEFORE INSERT ON student_age FOR EACH ROW BEGIN IF NEW.age < 0 THEN SET NEW.age = 0; END IF; END // Query OK, 0 rows affected (0.30 sec)
广告
数据结构
网络
关系数据库管理系统
操作系统
Java
iOS
HTML
CSS
Android
Python
C 语言编程
C++
C#
MongoDB
MySQL
Javascript
PHP