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

时间:2015-02-28 15:58:07

标签: mysql if-statement triggers

我是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值,但我是触发器的新手,无法弄清楚我的错误。

1 个答案:

答案 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 ;