我是mysql中触发器的新手,发现它们非常有用。我想要一个关于我正在创建的触发器的帮助。首先,我在update事件上创建了一个触发器,如下所示:
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
值,但我是触发器的新手,无法弄清楚我的错误。
答案 0 :(得分:0)
触发器语法不正确,您错过了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 ;