mysql 触发器新旧字段_在MySQL上更新触发器之前检查不在SET子句上的字段

我想设置一个更新前触发器,如果​​完成更新查询并且该列在set子句上没有新值,则将列设置为给定值.

我正在使用的表. (有点)

DROP TABLE IF EXISTS 'hex';

CREATE TABLE 'hex' (

'id' INT(11) NOT NULL AUTO_INCREMENT,

'chunk' VARCHAR(45),

'flag' TINYINT(1) NOT NULL DEFAULT '0',

PRIMARY KEY ('id')

);

所以,我想要做的是当hex.chunk获取一个新值而flag不是,flag设置为0.

例如

当前数据集

id chunk flag

1 "Antelope" 0

2 "Barracuda" 1

3 "Capybara" 0

4 "Dolphin" 1

运营和预期成果

情况1 UPDATE hex SET chunk =“Antelope”WHERE id = 1;不更新标志,因为块没有获得新值.

情况2 UPDATE hex SET chunk =“Elephant”WHERE id = 2;将标志更新为0,因为chunk更改其值并且没有传递flag的数据.

情况3 UPDATE hex SET chunk =“Capybara”,flag =’1’WHERE id = 3;查询的块和标志更新.

情况4 UPDATE十六进制SET chunk =“Ferrovax”,flag =’0’WHERE id = 3与情况3相同.

所以,我尝试过使用这个触发器,但似乎没有按照我希望的方式工作.

CREATE TRIGGER 'flag_the_hex'

BEFORE UPDATE ON 'hex'

FOR EACH ROW

BEGIN

IF (NEW.flag IS NULL AND NEW.chunk != OLD.chunk)

THEN

SET NEW.flag = 0;

END IF;

END

我认为我的主要困惑是如何在触发器中表示未更新的列中的新值.如果我只更新块列,那么标志的NEW值是如何表示的?空值?或者它还没有存在?

请记住,我正在使用的表中可能有更多列.

谢谢阅读.

编辑:我在StackOverflow上问过这个问题,并认为可能不适合提出这个问题.所以,我在这里问了这个并在那里删除了它.

解决方法:

flag将是UPDATE开始之前的状态.也许使用OLD.flag而不是NEW.flag感觉“正确”,至少在if中?

附加物

NEW.flag包含新值. NEW.flag< => OLD.flag检查它是否发生了变化.我怀疑是否有任何方法可以确定它是否已设定但未更改. (注意我使用的是“NULL-safe equal” operator.)

标签:mysql,trigger

来源: https://codeday.me/bug/20190806/1597813.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值