[英]MySQL Syntax Error on Trigger
我无法在MySQL 5.3上编译此触发代码:
CREATE TRIGGER crmenq_bur
BEFORE UPDATE
ON crmenquiries
FOR EACH ROW
BEGIN
IF ( NEW.feedback = OLD.feedback
AND NEW.notes = OLD.notes
AND NEW.estatus = OLD.estatus )
THEN
SET NEW.update_type = 'NN';
ELSE
SET NEW.update_type = 'SEN';
SET new.last_update2 = now();
END IF;
CASE
WHEN NEW.estatus != OLD.estatus AND NEW.estatus = 'FP3' THEN
SET NEW.uid_follow_up = NEW.uid_last_update_by;
SET NEW.follow_up_date = DATE_ADD ( date(), INTERVAL 3 MONTH );
WHEN NEW.estatus != OLD.estatus AND NEW.estatus = 'FP6' THEN
SET NEW.uid_follow_up = NEW.uid_last_update_by;
SET NEW.follow_up_date = DATE_ADD ( date(), INTERVAL 6 MONTH );
WHEN NEW.estatus != OLD.estatus AND NEW.estatus = 'FP9' THEN
SET NEW.uid_follow_up = NEW.uid_last_update_by;
SET NEW.follow_up_date = DATE_ADD ( date(), INTERVAL 9 MONTH );
WHEN NEW.estatus != OLD.estatus AND NEW.estatus = 'FP12' THEN
SET NEW.uid_follow_up = NEW.uid_last_update_by;
SET NEW.follow_up_date = DATE_ADD ( date(), INTERVAL 12 MONTH );
WHEN NEW.estatus NOT IN ( 'FP3', 'FP6', 'FP9', 'FP12' ) THEN
SET NEW.uid_follow_up = NULL;
SET NEW.follow_up_date = NULL;
END CASE;
END;
运行此命令时,出现以下错误:
[You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '), INTERVAL 3 MONTH ); WHEN NEW.estatus != OLD.estatus AND NEW.estatus = ' at line 18]
最初,我嵌套了IF,但改用CASE看看是否有什么不同。 当前的格式不是我最初使用的格式(如果避免重复相同的条件,则嵌套该格式),但是每次尝试均失败,则代码被更改,但我尝试过的任何方法都没有起作用。
列/表名称正确。
引发错误是由于调用MySQL date()
函数引起的。 它被错误地使用了。
我不确定您是否打算使用当前日期。
如果是,则可以对代码中的所有date()
用法使用以下任何建议。
curdate() -返回当前日期
current_date() -CURDATE()
同义词
current_date -CURDATE()
同义词
范例 :
mysql> select curdate(), current_date(), current_date;
+------------+----------------+--------------+
| curdate() | current_date() | current_date |
+------------+----------------+--------------+
| 2014-07-01 | 2014-07-01 | 2014-07-01 |
+------------+----------------+--------------+
您也可以使用date()
函数,但是它使用类型为date
, datetime
或timestamp
的输入参数。
范例 :
mysql> select date( sysdate() ), date( now() ), date( curtime() ), date( curdate() );
+-------------------+---------------+-------------------+-------------------+
| date( sysdate() ) | date( now() ) | date( curtime() ) | date( curdate() ) |
+-------------------+---------------+-------------------+-------------------+
| 2014-07-01 | 2014-07-01 | 2014-07-01 | 2014-07-01 |
+-------------------+---------------+-------------------+-------------------+
请参阅文档 :
在开始之前,使用Delimiter $$
类的内容更改定界符,并使用新的定界符结束触发器。 完成后将其改回,如下所示:
Delimiter $$
CREATE TRIGGER crmenq_bur
BEFORE UPDATE
ON crmenquiries
FOR EACH ROW
BEGIN
/* Body of code here */
END $$
Delimiter ;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.