我想设置一个更新前触发器,如果完成更新查询并且该列在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