首页 > 数据库 > mysql教程 > 为什么在删除后创建 MySQL 触发器以从表中删除时出现'检查第 6 行接近 END 的语法”错误?

为什么在删除后创建 MySQL 触发器以从表中删除时出现'检查第 6 行接近 END 的语法”错误?

Mary-Kate Olsen
发布: 2024-11-02 16:53:02
原创
237 人浏览过

Why Am I Getting a

MySQL 触发器:删除后从表中删除 - 语法错误和解决方案

尝试创建触发器以从“patron_info”中删除行时从“patrons”表中删除一行后,可能会遇到“检查第 6 行 END 附近的语法”的错误消息。此错误表示触发器代码中存在语法错误。

提供的触发器代码当前在 DELETE 语句的 WHERE 子句中存在语法错误:

DELETE FROM patron_info
    WHERE patron_info.pid = patrons.id
登录后复制

这里的问题是触发器使用“patrons”别名引用“patrons”表,该别名仅在触发器的 BEGIN 和 END 块中可用。要解决此问题,DELETE 语句应改为引用“旧”别名,它表示从“顾客”表中删除的行:

DELETE FROM patron_info
    WHERE patron_info.pid = old.id
登录后复制

经过此更正,触发器代码现在应该为:

CREATE TRIGGER log_patron_delete AFTER DELETE on patrons
FOR EACH ROW
BEGIN
DELETE FROM patron_info
    WHERE patron_info.pid = old.id;
END
登录后复制

此外,确保 DELETE 语句以分号 (;) 结尾以终止该语句也很重要。在控制台输入触发代码时,还应该使用分隔符来定义触发边界。

以上是为什么在删除后创建 MySQL 触发器以从表中删除时出现'检查第 6 行接近 END 的语法”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板