- 基本上与创建INSERT触发器一样,只不过在DELETE触发器中只能使用OLD来访问被删除的行数据 。
UPDATE触发器
- UPDATE触发器在UPDATE语句执行之前或者之后执行,需要知道一下几点:
- 在BEFORE UPDATE触发器中可以使用NEW和OLD来访问数据,而在AFTER UPDATE触发器中使用NEW来访问数据会报错,只能使用OLD来访问数据;
- 在BEFORE UPDATE触发器中,NEW中的值可以被改变,即允许更改将用于UPDATE的数据;
- OLD中的行数据只能读,不能被更新;
- 一个UPDATE触发器示例如下:
/*创建UPDATE触发器*/DELIMITER // CREATE TRIGGER insertcustomers BEFORE UPDATE ON customers FOR EACH ROWBEGINSELECT NEW.cust_name INTO @beforeupdate; SET NEW.cust_name = 'reset_name'; SELECT OLD.cust_name INTO @afterupdate; END ///*调用UPDATE触发器*/ UPDATE customers SET cust_name = 'happy' WHERE cust_id = 5; SELECT @beforeupdate; SELECT @afterupdate;复制代码
- 输出为@beforeupdate为‘happay’,而@afterupdate为'reset_name' 。有这样一些细节:
- NEW虚拟表中的数据可以更改,如这里采用 SET NEW.cust_name = 'reset_name';,将待更新的cust_name由“happy”变成了“reset_name”;
- 在BEFORE UPDATE触发器中可以使用NEW和OLD来访问数据,而在AFTER UPDATE触发器中使用NEW来访问数据会报错;
- 删除触发器?
- 删除触发器,可以使用 DROP TRIGGER语句,比如DROP TRIGGER insertcustomers; 。触发器不能更新或者覆盖,如果要修改触发器,必须删除这个触发器 。
来源:https://juejin.im/post/5ae55861f265da0ba062ec71
推荐阅读
-
证券时报|上半年楼市基本复苏 局部波动不改全年平稳趋势
-
iphone11|?iPhone11虽好但不建议买,10月份的这三款新机更值得!
-
宝宝牛奶蛋白过敏的症状不容小觑,做好预防工作至关重要
-
-
-
姑娘说我喜欢她是我的权力,她不能干预。好迷茫的体验
-
-
香港电影|真人真事改编的6部港片,全部惨遭封禁,你可能一部都没看过
-
精兵堂1 美媒:是中国又一里程碑,中国向全世界宣布!又一项技术崛起
-
-
-
海陆空战略库|多次袭击致使多人死亡,根本原因还是这个国家,塔利班又发飙
-
-
喜讯 ▎中智卫安与云迹科技达成战略合作,携手航行机器人蓝海
-
-
-
-
最好的朋友去世了,始终无法释怀,而且导致自己生活一团乱麻,咋办
-
-
杯酒品历史能被后世如此推崇,更被称为第六天大魔王,织田信长有何功绩