数据库

 首页 > 数据库 > MySql > MySQL触发器 trigger之after与before区分

MySQL触发器 trigger之after与before区分

分享到:
【字体:
导读:
         摘要:after:是先完成数据的增删改,然后再触发,触发的语句晚于监视的增删改,无法影响前面的增删改动作;也就是说先插入订单记录,再更新商品数量。当商品数量少于订单数量时造成爆库。before:先完成触发,在进行增删改,触发语句先于监视的增删改,我们就有机会判断,修改即将发生的操作。案例操作:触发器使用after:当某个订单...

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添加远程用户或允许远程访问三种方...
MYSQL添加远程用户或允许远程访问三种方法 添加远程用户admin密码为password GRANT ALL PRIVILEGES ON *.* TO admin@localhost IDENTIFIED BY \'password\' WITH GRANT OPTION GRANT ALL PRIVILEGES ON *.* TO admin@\"%\" IDENTIFIED BY \'password\' WITH GRANT OPTION mysql教程添加远程用户或允...
window下自动备份数据库成dmp格式的bat写...
window下自动备份数据库成dmp格式的bat写法复制下面的命令到一个txt文本文档,然后修改对应的参数为自己需要的参数,一切完成之后,将文件保存为bat格式。 这样每次需要备份的时候只需要双击一下这个bat文件,其他的都不用你了,你只需要静静的等待…… ///下面命令可以直接复制使用 @echo off echo 开始 REM ########...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……