mysql 触发器 插入语句_MySQL中insert触发器(插入)详解

INSERT触发器在有了前面的基础知识后,我们现在来看所支持的每种触发器类型以及它们的差别。INSERT 触发器在 INSERT 语句执行之前或之后执行。需要知道以下几点:1.在 INSERT 触发器代码内,可引用一个名为 NEW 的虚拟表,访问被插入的行;2.在 BEFORE INSERT 触发器中, NEW 中的值也可以被更新(允许更改被插入的值);3.对于 AUTO_INCREMENT 列,...
摘要由CSDN通过智能技术生成

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(),

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值