为什么在 MySQL 中删除重复项时出现'DELETE FROMEmployee WHERE (empid, empssn) NOT IN (...)\”错误?

Linda Hamilton
发布: 2024-11-01 16:24:31
原创
679 人浏览过

Why Does

删除 MySQL 表中的重复行:解决错误

从包含字段“empid”、“empname”的名为“employee”的表中删除重复记录,和 'empssn',首先使用查询来识别它们:

<code class="sql">SELECT COUNT(empssn), empssn FROM employee 
GROUP BY empssn 
HAVING COUNT(empssn) > 1</code>
登录后复制

但是,后续删除查询:

<code class="sql">DELETE FROM employee 
WHERE (empid, empssn) NOT IN (
    SELECT MIN(empid), empssn FROM employee 
    GROUP BY empssn
);</code>
登录后复制

在指定目标表 'employee' 时遇到错误FROM 子句。

解决方案:

要解决此错误,请将子查询包装在派生表中:

<code class="sql">DELETE FROM employee 
WHERE (empid, empssn) NOT IN (
    SELECT empid, empssn FROM (
        SELECT MIN(empid) AS empid, empssn FROM employee 
        GROUP BY empssn
    ) X
);</code>
登录后复制

此修改允许您在子查询中引用原始表并成功删除重复行。

以上是为什么在 MySQL 中删除重复项时出现'DELETE FROMEmployee WHERE (empid, empssn) NOT IN (...)\”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!