gpt4 book ai didi

mysql - DATEDIFF 在 BEFORE INSERT 触发器中返回 NULL

转载 作者:行者123 更新时间:2023-11-29 07:30:56 26 4
gpt4 key购买 nike

我创建了一个BEFORE INSERT 触发器。我想计算总天数。我有两列 leave_fromleave_to。现在我想减去这两列以设置 total_days

DELIMITER ;;
CREATE TRIGGER `leave_bi` BEFORE INSERT ON `leave` FOR EACH ROW
begin
set new.total_days=(select DATEDIFF('new.leave_from','new.leave_to'));
end;;

当我将数据插入表中时,total_days 变为 NULL。这是为什么?

最佳答案

您正在将字符串传递给 DATEDIFFDATEDIFF 将尝试将字符串 'new.leave_from''new.leave_to' 解析为日期,这将失败并因此返回 NULL

摆脱 ' 它应该可以工作:DATEDIFF(new.leave_from,new.leave_to)

关于mysql - DATEDIFF 在 BEFORE INSERT 触发器中返回 NULL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51322370/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com