一尘不染

如何从MySQL表中删除重复的行

mysql

我有一张MySQL像这样的桌子:

ID, Col1, Col2, Col3, Col4, etc...

ID为 primary key ,自创建表以来一直在使用。

我想要做的是删除除一个记录以外的所有记录,其中所有其他列都相同。


阅读 421

收藏
2020-05-17

共1个答案

一尘不染

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扩展到所有列。

编辑:我只是从保留的脚本中重新进行了测试,然后重新测试,它在MySQL中执行。

2020-05-17