How to delete duplicate rows from a MySQL table(如何从 MySQL 表中删除重复的行)
问题描述
我有一个 MySQL 表,例如:
I have a MySQL table like:
ID, Col1, Col2, Col3, Col4, etc...
ID 是一个主键,自表创建以来一直有效.
ID is a primary key and has been working since the table's creation.
我想要做的是删除所有其他列都相同的记录.
What I want to do is delete all but one records where all the other columns are identical.
推荐答案
DELETE DupRows.*
FROM MyTable AS DupRows
INNER JOIN (
SELECT MIN(ID) AS minId, col1, col2
FROM MyTable
GROUP BY col1, col2
HAVING COUNT(*) > 1
) AS SaveRows ON SaveRows.col1 = DupRows.col1 AND SaveRows.col2 = DupRows.col2
AND SaveRows.minId <> DupRows.ID;
当然,您必须将所有三个位置的 col1、col2 扩展到所有列.
Of course you have to extend col1, col2 in all three places to all columns.
我刚刚从我保留并重新测试的脚本中提取了它,它在 MySQL 中执行.
I just pulled this out of a script I keep and re-tested, it executes in MySQL.
这篇关于如何从 MySQL 表中删除重复的行的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何从 MySQL 表中删除重复的行
基础教程推荐
- MySQL根据从其他列分组的值,对两列之间的值进行求和 2022-01-01
- 使用 VBS 和注册表来确定安装了哪个版本和 32 位 2021-01-01
- ORA-01830:日期格式图片在转换整个输入字符串之前结束/选择日期查询的总和 2021-01-01
- MySQL 5.7参照时间戳生成日期列 2022-01-01
- CHECKSUM 和 CHECKSUM_AGG:算法是什么? 2021-01-01
- 带更新的 sqlite CTE 2022-01-01
- 从字符串 TSQL 中获取数字 2021-01-01
- 带有WHERE子句的LAG()函数 2022-01-01
- 如何在 CakePHP 3 中实现 INSERT ON DUPLICATE KEY UPDATE aka upsert? 2021-01-01
- while 在触发器内循环以遍历 sql 中表的所有列 2022-01-01
