34、before和after区别

类似饭店吃饭:
    1.饭前付款----如果没钱,不让吃
    2.饭后付款----如果没钱,也没办法

下订单减库存:
insert into o values (2,4,100);  2号订单,4号商品100件
实际上4号商品只有8件。

触发器里after和before的区别
after是先完成数据的增删改,再触发
触发中的语句晚于增删改,无法影响前面的增删改

before是先完成触发,再增删改
触发的语句先于监视的增删改发生,因此有机会审查、判断并修改即将发生的操作

典型案例:
对于所下订单进行判断,如果订单数量大于5,就认为是恶意订单,强制将锁定的商品数量改成5

监视地点    o表
监视事件    insert
触发事件    update
触发时间    before
目的            触发事件先于监视事件发生,并判断监视事件的数据
create trigger tg5
before insert on o
for eache row
begin
    if new.much > 5 then
        new.much = 5;
    end if;
    update g set num = num - new.much where id = new.gid;
end$

select * from o $
select * from g $
insert into o values (2,4,20)$
select * from o$
select * from g$

如何查看所有触发器:
show triggers;


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/24103417/viewspace-1415096/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/24103417/viewspace-1415096/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值