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 ;
MySQL触发器实例(记录触发器)_第1张图片
2:查询商品表
MySQL触发器实例(记录触发器)_第2张图片
3:插入数据
INSERT INTO t_order VALUES(NULL,3,10);
MySQL触发器实例(记录触发器)_第3张图片

你可能感兴趣的:(MySQL数据库)