MySQL触发器实例(记录触发器)

MySQL:记录触发器
1:概述
1:不管触发器是否触发,只要当某种操作准备执行,系统就会将当期要操作的记录的当期状态和即将执行之后新的状态分别保留下来,提供给触发器使用,其中,要操作当期状态保存到old中,操作之后的可能形态保存给new
2:old和new
1: old代表的是旧记
2: new代表的是新记录
3; 删除的时候是没有new(删除后数据为空了)的,插入的时候没有old
4: old和new都代表记录本身,任何一条记录除了有数据,还有字段名字
使用方式: old 字段名 new.字段名(new 代表假设之后的结果)
3:案例DEMO(优化创建触发器的SQL)
1:创建触发器
注意什么时候使用new,什么时候使用old
DELIMITER $$
CREATE TRIGGER AFTER_order AFTER INSERT ON t_order FOR EACH ROW
BEGIN
--触发器内容开始:新增一条记录:OLD没有,NEW代表新的订单记录
--UPDATE t_goods SET inv=inv-1 WHERE id=2;
UPDATE t_goods SET inv= inv-new.g_nummer WHERE id=new.g_id;
END $$
DELIMITER ;

2:查询商品表

3:插入数据
INSERT INTO t_order VALUES(NULL,3,10);

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值