在触发器中添加 if else 语句时出错 mysql
error on adding if else statement inside trigger mysql
我是 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
。另外你的触发器是 before update
所以你不需要再次在触发器中使用更新命令。您可以只设置列的值。
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 中的触发器新手,发现它们非常有用。我需要有关我正在创建的触发器的帮助。首先,我创建了一个更新事件触发器,如下所示:
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
。另外你的触发器是 before update
所以你不需要再次在触发器中使用更新命令。您可以只设置列的值。
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 ;