Mybatis中使用MySql触发器报错:You have an error in your SQL syntax; ‘DELIMITER $$

前提:

在写数据库作业时候,使用SpringBoot2.7.x+Mybatis-plus+Mysql8.0开发,其中使用MySQL的触发器时报以下错误:

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 cleanup after update on manual_reco' at line 1

错误是因为 MySQL 不识别 DELIMITER 命令,通常这是因为你在不支持 DELIMITER 命令的环境中执行 SQL 语句。

DELIMITER 命令的作用:

在 MySQL 命令行客户端(比如 MySQL CLI 或者 MySQL Workbench)中,DELIMITER 命令用来改变 SQL 语句的结束符,默认是 ; 但在定义存储过程、触发器等时,内部可能会使用 ;,这时需要修改结束符。例如,将结束符改为 $$,这样 MySQL 就可以区分语句结束和触发器内部的分号。

错误原因

  1. 环境不支持 DELIMITER :一些图形化的 SQL 编辑器或者数据库管理工具(比如 phpMyAdmin、Navicat、DBeaver 等)不支持 DELIMITER 命令,因此你在这些环境中执行时会报错。

  2. 在 SQL 文件中使用 DELIMITER :如果你将 SQL 语句放在一个 SQL 文件中,并直接通过数据库管理工具执行(而不是通过命令行工具),DELIMITER 也可能无法正常工作。

解决方法

  1. 避免使用 DELIMITER : 如果你在图形化的 SQL 编辑器中执行 SQL,通常不需要使用 DELIMITER。你可以直接去掉 DELIMITER 语句,将触发器定义写成一个普通的 SQL 语句:

    CREATE TRIGGER cleanup AFTER UPDATE ON manual_record FOR EACH ROW BEGIN -- 触发器逻辑 DELETE FROM manual_record WHERE is_leave = 1 AND out_time < DATE_SUB(NOW(), INTERVAL 1 YEAR); END;

  2. 通过命令行执行 SQL 文件 : 如果你通过 MySQL 命令行工具执行 SQL 文件,可以在文件中使用 DELIMITER 命令。如果你使用的是其他工具,确保该工具支持 DELIMITER 命令,或者根据该工具的要求调整 SQL 语法。


总结

  • 命令行工具 :可以使用 DELIMITER 命令修改语句结束符,便于定义触发器和存储过程。
  • 图形化工具 :避免使用 DELIMITER,直接使用常规的 SQL 语句。
  • 只要遇到这个问题,首先确认执行 SQL 的环境是否支持 DELIMITER 语法。
相关推荐
r***93481 天前
CentOS7安装Mysql5.7(ARM64架构)
adb·架构
q***57742 天前
MySql的慢查询(慢日志)
android·mysql·adb
翔云1234562 天前
MySQL 机器重启后,gtid_executed 是如何初始化的
数据库·mysql·adb
d***95622 天前
docker 安装 mysql
mysql·adb·docker
3***89192 天前
开放自己本机的mysql允许别人连接
数据库·mysql·adb
Kaede62 天前
MySQL中如何使用命令行修改root密码
android·mysql·adb
1***t8272 天前
MySQL 8.0安装
数据库·mysql·adb
3***g2052 天前
Linux系统离线部署MySQL详细教程(带每步骤图文教程)
linux·mysql·adb
i***t9192 天前
Linux下MySQL的简单使用
linux·mysql·adb
q***57743 天前
MySQL 实验1:Windows 环境下 MySQL5.5 安装与配置
windows·mysql·adb