MySQL触发器 trigger之after与before区分

Posted yxysuanfa

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL触发器 trigger之after与before区分相关的知识,希望对你有一定的参考价值。

after:是先完毕数据的增删改,然后再触发。触发的语句晚于监视的增删改,无法影响前面的增删修改作。也就是说先插入订单记录。再更新商品数量。当商品数量少于订单数量时造成爆库。

before:先完毕触发,在进行增删改,触发语句先于监视的增删改,我们就有机会推断,改动即将发生的操作。
案例操作:
触发器使用after
当某个订单的数量超过库存的数量时会出现库存为负数。造成所谓的爆库问题。
#创建触发器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$$
技术分享





以上是关于MySQL触发器 trigger之after与before区分的主要内容,如果未能解决你的问题,请参考以下文章

mysql之触发器trigger

mysql之触发器trigger

mysql trigger 触发器

MySQL触发器trigger

MySQL 使用触发器记录用户的操作日志

MySQL Trigger AFTER INSERT ON 'table name' FOR EACH ROW WHEN (role_id = 3)