我是靠谱客的博主 淡淡棉花糖,最近开发中收集的这篇文章主要介绍mysql 触发器 插入语句_MySQL中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);

输出:

16dbfa8707602f128862d937d47bf7a3.png

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

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

【相关推荐】

最后

以上就是淡淡棉花糖为你收集整理的mysql 触发器 插入语句_MySQL中insert触发器(插入)详解的全部内容,希望文章能够帮你解决mysql 触发器 插入语句_MySQL中insert触发器(插入)详解所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(53)

评论列表共有 0 条评论

立即
投稿
返回
顶部