OLD 和 NEW 关键字如何让我们访问受触发器影响的行中的列?

mysqlmysqli database

我们知道,在触发器定义中,我们可以引用被插入、更新或删除的行中的列。以下是 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)

相关文章