
正如我们所知,在触发器定义中,我们可以引用正在插入、更新或删除的行的列。以下是OLD和NEW关键字使我们能够访问列的方式:
我们必须在列名前加上一个OLD限定符,以引用原始行中的值。
我们必须在列名前加上NEW限定符,以引用新行中的值。
现在,必须适当地使用OLD和NEW,因为触发事件
确定哪些是允许的 −
在INSERT触发器中,NEW.column_name表示要插入到新行中的列值。这里不允许使用OLD。
绘影字幕
视频字幕制作神器、轻松编辑影片
69 查看详情
在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 ONstudent_age FOR EACH ROWBEGINIF NEW.age < 0 THEN SET NEW.age = 0;END IF;END //Query OK, 0 rows affected (0.30 sec)
以上就是”OLD和NEW关键字使我们能够访问受触发器影响的行中的列。”的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/224504.html
微信扫一扫
支付宝扫一扫