MySQL trigger #39;update on column#39; syntax(MySQL 触发“列更新语法)
问题描述
我们可以在更新特定列时使用 MySQL 触发器,从而更新同一表(同一行)中的另一列
Can we use a MySQL trigger on update of specific columns, which updates another column in same table (same row)
create trigger my_trigger
BEFORE UPDATE OF col1, col2 ON TABLE_NAME
for each row
set NEW.col3 = NEW.col3 +1;
我使用 UPDATE OF col1, col2
尝试了上述代码.它在 MySQL 中不起作用.什么是正确的语法,有人能指点我一些例子吗.
I tried the above code using UPDATE OF col1, col2
. It is not working in MySQL. What is the correct syntax, can somebody point me to some examples.
推荐答案
您不能指定触发器仅在特定列的更新时运行(UPDATE
会影响整个记录),但您可以测试触发器中哪些列已更新:
You can't specify that the trigger is to be run only on the update of specific columns (an UPDATE
affects the entire record), but you can test which columns have been updated within your trigger:
DELIMITER ;;
CREATE TRIGGER my_trigger BEFORE UPDATE ON TABLE_NAME FOR EACH ROW
IF NOT (NEW.col1 <=> OLD.col1 AND NEW.col2 <=> OLD.col2) THEN
SET NEW.col3 = NEW.col3 + 1;
END IF;;
DELIMITER ;
这篇关于MySQL 触发“列更新"语法的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:MySQL 触发“列更新"语法


基础教程推荐
- MySQL 5.7参照时间戳生成日期列 2022-01-01
- 使用 VBS 和注册表来确定安装了哪个版本和 32 位 2021-01-01
- ORA-01830:日期格式图片在转换整个输入字符串之前结束/选择日期查询的总和 2021-01-01
- 带更新的 sqlite CTE 2022-01-01
- 带有WHERE子句的LAG()函数 2022-01-01
- 从字符串 TSQL 中获取数字 2021-01-01
- CHECKSUM 和 CHECKSUM_AGG:算法是什么? 2021-01-01
- 如何在 CakePHP 3 中实现 INSERT ON DUPLICATE KEY UPDATE aka upsert? 2021-01-01
- while 在触发器内循环以遍历 sql 中表的所有列 2022-01-01
- MySQL根据从其他列分组的值,对两列之间的值进行求和 2022-01-01