MySQL 如何使用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可以用于读取或更改列值。
阅读更多:MySQL 教程
在触发器中使用OLD关键字
以下是删除触发器的示例,显示了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)