明辉手游网中心:是一个免费提供流行视频软件教程、在线学习分享的学习平台!

MySQL中insert触发器(插入)详细说明

[摘要]INSERT触发器在有了前面的基础知识后,我们现在来看所支持的每种触发器类型以及它们的差别。INSERT 触发器在 INSERT 语句执行之前或之后执行。需要知道以下几点:1.在 INSERT 触发器代码内,可引用一个名为 NEW 的虚拟表,访问被插入的行;2.在 BEFORE INSERT 触发...
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);

输出:

1.png

分析:orders 包 含 3 个 列 。 order_date 和 cust_id 必 须 给 出 ,order_num 由MySQL自动生成,而现在 order_num 还自动被返回。

BEFORE 或 AFTER ? 通常,将 BEFORE 用于数据验证和净化(目的是保证插入表中的数据确实是需要的数据)。本提示也适用于 UPDATE 触发器。

【相关推荐】

1. mysql免费视频教程

2. mysql触发器简介及如何创建和删除触发器

3. MySQL使用字符集和校对顺序使用教程

4. MySQL字符集和校对顺序简介

5. MySQL事务-使用保留点、更改默认的提交行为详解

以上就是MySQL中insert触发器(插入)详解的详细内容,更多请关注php中文网其它相关文章!


学习教程快速掌握从入门到精通的SQL知识。