gpt4 book ai didi

mysql - 在触发器mysql中添加if else语句时出错

转载 作者:行者123 更新时间:2023-11-29 22:54:18 27 4
gpt4 key购买 nike

我是 mysql 触发器的新手,发现它们非常有用。我需要有关我正在创建的触发器的帮助。首先,我创建了一个更新事件触发器,如下所示:

CREATE TRIGGER `after_mytable_update` BEFORE UPDATE ON `my_table`
FOR EACH ROW SET NEW.total_pts=NEW.pts_1+NEW.pts_2+NEW.pts_3,
NEW.old_pts=OLD.total_pts

效果很好。现在,我需要在触发器中添加 if/else。因此,我删除并重新创建了触发器,如下所示:

CREATE TRIGGER `after_mytable_update` BEFORE UPDATE ON `my_table`
FOR EACH ROW SET NEW.total_pts=NEW.pts_1+NEW.pts_2+NEW.pts_3,
NEW.old_pts=OLD.total_pts;
IF (NEW.total_pts>=0) THEN
UPDATE 'my_table' SET NEW.level='my_value';
END IF;

但它给出错误#1064。我需要在 if/else 语句之外设置 total_pts 值,但我对触发器不熟悉,无法找出我的错误。

最佳答案

触发器语法不正确,您缺少begin,它应该如下所示。此外,您还缺少分隔符。此外,您的触发器是更新之前,因此您不需要再次在触发器内使用更新命令。您只需设置该列的值即可。

delimiter //
CREATE TRIGGER `after_mytable_update` BEFORE UPDATE ON `my_table`
FOR EACH ROW
begin
SET NEW.total_pts=NEW.pts_1+NEW.pts_2+NEW.pts_3;
set NEW.old_pts=OLD.total_pts;
IF NEW.total_pts>=0 THEN
SET NEW.level='my_value';
END IF;
end; //

delimiter ;

关于mysql - 在触发器mysql中添加if else语句时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28783702/

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