当前位置:Gxlcms > 数据库问题 > MySQL触发器 trigger之after与before区分

MySQL触发器 trigger之after与before区分

时间:2021-07-01 10:21:17 帮助过:7人阅读

使用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区分

标签:pre   test   creat   动态   blog   iss   库存   最大数   enter   

人气教程排行