• mysql之触发器before和after的区别


    我们先做个测试:

    接上篇日志建的商品表g和订单表o和触发器

    假设:假设商品表有商品1,数量是10;

    我们往订单表插入一条记录:

    insert into o(gid,much) values(1,20);

    会发现商品1的数量变为-10了。这就是问题的所在,因为我们之前创建的触发器是after,也就是说触发的语句是在插入订单记录之后才执行的,这样我们就无法判断新插入订单的购买数量。

    先讲一下after和before的区别:

    after是先完成数据的增删改,再触发,触发的语句晚于监视的增删改操作,无法影响前面的增删改动作;也就是说先插入订单记录,再更新商品的数量;

    before是先完成触发,再增删改,触发的语句先于监视的增删改,我们就有机会判断,修改即将发生的操作;

    我们用一个典型案例来区分它们的区别,新建一个触发器:

    #监视地点: 商品表o

    #监视事件:insert

    #触发时间:before

    #触发事件:update

    案例:当新增一条订单记录时,判断订单的商品数量,如果数量大于10,就默认改为10

    create trigger tg6

    before insert on o

    for each row

    begin

      if new.much > 10 then

        set new.much = 10;

      end if;

      update g set num = num - new.much where id = new.gid;

    end$

    执行完,把之前创建的after触发器删掉,再来插入一条订单记录:

    insert into o(gid,much) valus(1,20)$

    执行完会发现订单记录的数量变为10,商品1的数量变为0了,就不会出现负数了。

    显示触发器:show triggers;

  • 相关阅读:
    [Codeforces 339D] Xenia and Bit Operations
    [Codeforces 459D] Pashmak and Parmida's problem
    [Codeforces 460C] Present
    [Codeforces 466C] Number of Ways
    [Codeforces 650A] Watchmen
    Linux系统中‘dmesg’命令处理故障和收集系统信息的7种用法
    select函数详解
    都是stm32的JTAG引脚惹的祸
    uboot中的快捷菜单的制作说明
    卷积的本质及物理意义(全面理解卷积)
  • 原文地址:https://www.cnblogs.com/a757956132/p/4314926.html
Copyright © 2020-2023  润新知