触发器中使用BEFORE INSERT更改新插入记录中的某些字段值

要求实现:A表中不断有数据自动插入,需要做到,在新数据插入进A表之间之前,获取将要插入数值中的某一项,以此项为条件,查询另一个表B,将查询到的结果更新到A表中

相关知识:

关键字before和after用于标识触发时间,顾名思义,before代表触发器里面的命令在DML修改数据之前执行,after代表触发器里面的命令在DML修改数据之后执行。

declare定义的类似是局部变量

new在before触发器中赋值,取值;

在mysql触发器中,官方说可能使用了update会导致死循环,推荐我们直接使用new赋值变量.

我们只要利用SET new.name = _name;就可以代替update了。

注意如图,尽量不要使用多个变量用一个名称。我在第一次写的时候,在declare中直接写的spydata_username ,全文都用的spydata_username,一直出问题,最后改为spydata_usernamee后问题才消失。文中的括号最好也要写上。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值