本文介绍: 某天,正按照业务的要求删除不需要的数据,在执行 DELETE 语句时,竟然出现了报错!作者:林靖华,开源数据库技术爱好者,擅长MySQL和Redis的运维爱可生开源社区出品,原创内容未经授权不得随意使用,转载请联系小编并注明来源。本文约 650 字,预计阅读需要 2 分钟。
某天,正按照业务的要求删除不需要的数据,在执行 DELETE 语句时,竟然出现了报错!
背景
某天,正按照业务的要求删除不需要的数据,在执行 DELETE 语句时,竟然出现了报错(MySQL 数据库版本 5.7.34):
这就有点奇怪了,因为我在执行删除语句之前,执行过同样条件的 SELECT 语句,只是把其中的 select *
换成了 delete
而已,毕竟这个语法的报错一般来说原因很大可能是 关键字拼写错误 或者 存在中文符号。
排除了上面的原因后,再从语句本身的逻辑来排查,难道说 DELETE 语句不支持 not exists
这种写法?好像之前也没听说过这个限制。我们还是以语法错误这个原因为起点,去查查官方文档看下能不能找出答案。
分析
DELETE 的语法如下:
5.7 单表删除格式
仔细对比了以下,发现了一些端倪,这里的语法并没有写出表名的别名用法,难道是使用了别名的原因?
8.0 单表删除格式
5.7 和 8.0 多表删除格式
结论
关于 SQLE
SQLE 获取
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。