MySQL触发器 trigger之after与before区分
2014-10-23 14:07
691 查看
after:是先完成数据的增删改,然后再触发,触发的语句晚于监视的增删改,无法影响前面的增删改动作;也就是说先插入订单记录,再更新商品数量。当商品数量少于订单数量时造成爆库。
before:先完成触发,在进行增删改,触发语句先于监视的增删改,我们就有机会判断,修改即将发生的操作。
案例操作:
触发器使用after:
当某个订单的数量超过库存的数量时会出现库存为负数。造成所谓的爆库问题。
触发器使用before:
先触发,在判断处理之后再进行增删改不会,根据库存修改了订单的最大数量。当然我这只是简单的固定了一个值,其实可以用语句获取到动态的库存值。
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触发器 trigger之after与before区分
- setUp()、tearDown()、setUpBeforeClass()、tearDownAfterClass()的区分
- Oracle Trigger :Before,after,each row and table level triggers ORA-04082 ORA-04084
- Oracle —— before row trigger OR after row trigger
- oracle trigger中的before和after
- Jquery基础:append、prepend、after、before、appendTo的区别
- CSS伪类:before 和 :after
- 浏览器f12, ::before ::after是什么意思?
- 首页 > 程序开发 > 软件开发 > Java > 正文 Java中单元测试中:@BeforeClass,@Before,@Test,@After,@AfterClass中的问题详解
- css 伪元素 :hover :active :before :after :visited :link :focus ...
- JQuery中html、append、appendTo、after、insertAfter、before、insertBefore、empty、remove的使用
- ::before和::after伪元素的用法
- 关于伪类元素:before和:after
- jquery append appendTo before after insertAfter insertBefore prepend prependTo用法区别
- ThinkPHP中_after_update、_before_update等的用法
- 关于jiffies回绕以及time_after,time_before
- javascript插入before(),after()新DOM方法
- (org.jbehave.core.failures.BeforeOrAfterFailed: webdriver selenium错误解决。
- [DIV/CSS] CSS 属性 :before && :after的用法,伪类和伪元素的区别