OLD和NEW关键字如何使我们能够访问受触发器影响的行中的列?
众所周知,在触发器定义中,我们可以引用要插入,更新或删除的行的列。以下是OLD和NEW关键字使我们能够访问列的方式-
我们必须在列名前加上OLD限定符,以引用原始行中的值。
我们必须在列名前面加上NEW限定符,以引用新行中的值。
现在,必须适当地使用OLD和NEW,因为触发事件
确定其中哪些是允许的-
在INSERT触发器中,NEW.column_name指示要插入到新行中的列值。在这里OLD是不允许的。
在DELETE触发器中,OLD.column_name指示要删除的行中的列的值。在这里不允许新建。
在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; //
在触发器中使用关键字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 //