INSERT触发器
在有了前面的基础知识后,我们现在来看所支持的每种触发器类型以及它们的差别。
INSERT 触发器在 INSERT 语句执行之前或之后执行。需要知道以下几点:
1.在 INSERT 触发器代码内,可引用一个名为 NEW 的虚拟表,访问被插入的行;
2.在 BEFORE INSERT 触发器中, NEW 中的值也可以被更新(允许更改被插入的值);
3.对于 AUTO_INCREMENT 列, NEW 在 INSERT 执行之前包含 0 ,在 INSERT执行之后包含新的自动生成值。
下面举一个例子(一个实际有用的例子)。 AUTO_INCREMENT 列具有MySQL自动赋予的值。确定新生成值的方法,但下面是一种更好的方法:
输入:
create trigger neworder after insert on orders for each row select new .order_num;
分析:此代码创建一个名为 neworder 的触发器,它按照 AFTER INSERT ON orders 执行。在插入一个新订单到 orders 表时,MySQL生成一个新订单号并保存到 order_num 中。触发器从 NEW.order_num 取得这个值并返回它。此触发器必须按照 AFTER INSERT 执行,因为在 BEFORE INSERT 语句执行之前,新 order_num 还没有生成。对于 orders 的每次插入使用这个触发器将总是返回新的订单号。
为测试这个触发器,试着插入一下新行,如下所示:
输入:
insert into orders(order_date,cust_id) values(now(),10001);
输出:
分析:orders 包 含 3 个 列 。 order_date 和 cust_id 必 须 给 出 ,order_num 由MySQL自动生成,而现在 order_num 还自动被返回。
BEFORE 或 AFTER ? 通常,将 BEFORE 用于数据验证和净化(目的是保证插入表中的数据确实是需要的数据)。本提示也适用于 UPDATE 触发器。
【相关推荐】
1. mysql免费视频教程
Atas ialah kandungan terperinci MySQL中insert触发器(插入)详解. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!