在MySQL上更新触发器之前检查不在SET子句上的字段
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了在MySQL上更新触发器之前检查不在SET子句上的字段,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1596字,纯文字阅读大概需要3分钟。
内容图文
我想设置一个更新前触发器,如果??完成更新查询并且该列在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上更新触发器之前检查不在SET子句上的字段全部内容,希望文章能够帮你解决在MySQL上更新触发器之前检查不在SET子句上的字段所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。