Rumah  >  Artikel  >  pangkalan data  >  MySQL中insert触发器(插入)详解

MySQL中insert触发器(插入)详解

巴扎黑
巴扎黑asal
2017-05-19 15:25:426657semak imbas

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事务-使用保留点、更改默认的提交行为详解

Atas ialah kandungan terperinci MySQL中insert触发器(插入)详解. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn