我的应用程序中的业务逻辑要求我在表Y中插入行时在表X中插入一行。此外,它应该只在特定时间(我必须查询另一个表)之间执行。我已经考虑过每5分钟左右运行一次脚本来检查这个,但我偶然发现了触发器,并认为这可能是一种更好的方法。
但我发现程序的语法有点令人困惑,我不断收到错误,我不知道如何修复。这是我开始的地方:
CREATE TRIGGER reservation_auto_reply
AFTER INSERT ON reservation
FOR EACH ROW
BEGIN
IF NEW.sent_type = 1 /* In-App */
THEN INSERT INTO `messagehistory` (`trip`, `fk`, `sent_time`, `status`, `message_type`, `message`)
VALUES (NEW.trip, NEW.psk, 'NOW()', 'submitted', 4, 'This is an automated reply to reservation');
END;
我在statmenet的VALUES部分出错,但我不知道在哪里。我仍然需要在另一个表中查询我需要的信息,但我甚至无法通过这一部分。任何帮助表示赞赏,包括许多例子的链接。谢谢
答案 0 :(得分:2)
我不知道您为reservation.sent_time
的数据类型定义了什么,但我注意到您将NOW()
函数放在引号中,使其成为文字字符串{{1}而不是函数调用来获取当前时间。
好的,这是另外两个问题:
首先,MySQL触发器语言中的IF
statement在块之后需要'NOW()'
。
其次,您使用的是END IF;
吗?例如:
DELIMITER
这是必需的,因为mysql客户端允许您以交互模式或SQL脚本运行多个语句。但它有点愚蠢 - 它将输入视为一个SQL语句,直到它到达语句的终止符。通常,终结符是分号(DELIMITER //
CREATE TRIGGER reservation_auto_reply
AFTER INSERT ON reservation
FOR EACH ROW
BEGIN
IF NEW.sent_type = 1 /* In-App */
THEN
INSERT INTO `messagehistory` (`trip`, `fk`, `sent_time`, `status`, `message_type`, `message`)
VALUES (NEW.trip, NEW.psk, NOW(), 'submitted', 4, 'This is an automated reply to reservation');
END IF;
END//
DELIMITER ;
)。
但你的触发器体内有字面分号!如果mysql客户端在第一个分号处停止,它将尝试使用不完整的语句定义您的触发器。
mysql客户端中的解决方案是暂时将语句终止符更改为不出现在触发器主体中的其他字符或字符序列。例如:;
。
(请注意,//
命令是mysql客户端的内置命令。如果从应用程序执行动态SQL语句,则无法识别。)