MySQL触发器trigger之after与before区分_MySQL
程序员文章站
2024-01-30 09:23:22
...
after:是先完成数据的增删改,然后再触发,触发的语句晚于监视的增删改,无法影响前面的增删改动作;也就是说先插入订单记录,再更新商品数量。当商品数量少于订单数量时造成爆库。
before:先完成触发,在进行增删改,触发语句先于监视的增删改,我们就有机会判断,修改即将发生的操作。
案例操作:
触发器使用after:
当某个订单的数量超过库存的数量时会出现库存为负数。造成所谓的爆库问题。
触发器使用before: 先触发,在判断处理之后再进行增删改不会,根据库存修改了订单的最大数量。当然我这只是简单的固定了一个值,其实可以用语句获取到动态的库存值。
#创建触发器test4 CREATE TRIGGER test4 AFTER INSERT ON `ord` FOR EACH ROW BEGIN UPDATE goods SET num= num - new.much WHERE goods_id = new.gid; END$$
触发器使用before: 先触发,在判断处理之后再进行增删改不会,根据库存修改了订单的最大数量。当然我这只是简单的固定了一个值,其实可以用语句获取到动态的库存值。
#创建触发器test5 CREATE TRIGGER test5 BEFORE INSERT ON `ord` FOR EACH ROW BEGIN IF new.much >26 THEN SET new.much = 26; END IF; UPDATE goods SET num= num - new.much WHERE goods_id = new.gid; END$$
下一篇: 杀掉(kill)Oracle中会话或死锁
推荐阅读
-
MySQL触发器trigger之after与before区分_MySQL
-
MySQL触发器trigger之after与before区分_MySQL
-
MySQL触发器trigger之foreachrow_MySQL
-
MySQL触发器trigger之foreachrow_MySQL
-
Mysql之触发器Trigger
-
MySQL(InnoDB剖析):19---table之(约束与数据完整性(唯一/主键/外键/enum/set/触发器约束、约束和索引区别、sql_mode))
-
MySQL(InnoDB剖析):30---锁之(MySQL锁简介、lock与latch的区分)
-
【MySQL 14】触发器after和before
-
【MySQL 14】触发器after和before