3

我正在使用 Aurora Serverless MySQL 5.6 创建以下触发器,该触发器将在将数据插入另一个表但收到语法错误时更新一个表,特别是在 Delimiter 关键字周围。

DELIMITER $$
CREATE TRIGGER Create_Media_Like_Trigger AFTER INSERT ON MediaLike
FOR EACH ROW
BEGIN 
    IF NEW.likeType = 'LIKE' THEN
        UPDATE Media 
        SET Media.numLikes = Media.numLikes + 1 
        WHERE Media.mediaId = NEW.mediaId;
    ELSEIF NEW.likeType = 'DISLIKE' THEN
        UPDATE Media 
        SET Media.numLikes = Media.numLikes - 1 
        WHERE Media.mediaId = NEW.mediaId;
    ENDIF;
END $$
DELIMITER ;

就像我上面说的,我在 附近收到语法错误DELIMITER,这个问题是 AWS 特有的,我该如何解决?

更新错误消息:

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 'DELIMITER $$ CREATE TRIGGER Create_Media_Like_Trigger 
AFTER INSERT ON MediaLike ' at line 1

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 'ELSEIF NEW.likeType = 'DISLIKE' THEN UPDATE Media SET 
Media.numLikes = Media.num' at line 1

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 'END $$' at line 1
4

3 回答 3

2

我花了一天的时间试图弄清楚这一点,所以希望这可以帮助那里的人......

DELIMITER是客户端的功能,而不是 MySQL 服务器。RDS 查询编辑器是一个客户端,但它不支持更改分隔符,因此尝试运行您提供的脚本将不起作用,因为它第一次看到分号时会将其解释为命令的结尾并失败语法错误。

那么,如何创建像存储过程这样的东西,其中包含多个语句和分号?您必须将其创建为.sql文件并使用数据 API 从 Lambda 函数或 CLI 发送。

.sql首先,在没有任何DELIMITER命令或备用分隔符的文件中创建脚本。

例如:function.sql

CREATE PROCEDURE simpleproc (OUT param1 INT)
BEGIN
   SELECT COUNT(*) INTO param1 FROM t;
END

然后,使用 CLI 运行脚本,如下所示:

cat function.sql | xargs -0 aws rds-data execute-statement \
    --resource-arn arn:aws:rds:eu-west-1:xxx:cluster:cluster-name \
    --secret-arn arn:aws:secretsmanager:eu-west-1:xxx:secret:secret-name-xxx \
    --database "database_name" \
    --sql

或者,您可以创建一个 Lambda 函数来读取文件并用于rds_client.execute_statement()通过数据 API 将脚本发送到服务器。但同样,不要使用该DELIMITER语句。服务器看到BEGINandEND行并相应地采取行动,而无需更改分隔符。

于 2020-02-19T20:59:20.597 回答
0

After quite a while of messing with the DELIMITER keyword, I found the following works.

DROP FUNCTION sf_CheckUser;
DELIMITER / / 
CREATE FUNCTION db1.sf_CheckUser (
    userUUID VARCHAR(255),
    groupUUID VARCHAR(255),
    requiredTHING INT
) RETURNS TINYINT(1) 
BEGIN
DECLARE permit TINYINT(1);
        
  -- BODY OF FUNCTION

END / / DELIMITER;

于 2022-02-07T16:57:56.523 回答
0

此信息可能与 OP 的问题并不严格相关,但它密切相关,并且可以帮助处于类似情况的其他人(即来自搜索)。

我在 Amazon Aurora Serverless MySQL 5.6 数据库上运行了类似的CREATE FUNCTION查询,并且遇到了相同的语法错误。我使用 Table Plus (v2.9.1, build 264) 作为我的应用程序/客户端。

解决方案是删除 2xDELIMITER行。应用程序/客户端足够智能,可以自行计算定界符。

于 2019-10-15T04:17:23.367 回答