zoukankan      html  css  js  c++  java
  • MySQL数据库触发器(trigger)

    MySQL触发器(trigger):监视某种情况并触发某种操作 

    一:四要素

    触发时间:before/after

    地点:table

    监视操作:insert/update/delete

    触发操作:insert/update/delete

    二:创建触发器

    delimiter $     #将sql结束符改为$  方便写触发的sql语句

    create trigger triggerName after/before insert/update/delete on tableName

    for each row

    begin

       sql语句;   #想要触发的语句

    end$

    測试表:商品表(g)。订单表(o)

    三:删除监视器

    drop trigger triggerName

    四:下定单(o)。商品表(g)数据触发更新

    create trigger tg after insert on o

    for each row

    begin

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

    end$

     

    PS:对于监视操作insert 而言,新增的行用new 表示

            行中的每一列的值,用new.列名 取出

     

    五:删除一个订单,商品表对应添加

    create trigger tg after delete on o

    for each row

    begin

    update g set num=num+old.much where id=old.gid;

    end$

     

    六:改动一个订单。商品表对应改变

    create trigger tg after update on o

    for each row

    begin

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

    end$

     

    七:after与before差别

    after 是先完毕数据的增删改,再触发,前面的数据操作完毕

    before是先触发,推断触发的条件是否满足,再对数据进行增删改操作

  • 相关阅读:
    上学路线 (Standard IO)
    舞台设置 (Standard IO)
    Circle (Standard IO)
    Number (Standard IO)
    Gift (Standard IO)
    圆周舞蹈 (Standard IO)
    竞赛排名 (Standard IO)
    奶牛排队 (Standard IO)
    奶牛晒衣服 (Standard IO)
    神奇的风 (Standard IO)
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/5184900.html
Copyright © 2011-2022 走看看