MySQL 中删除重复的数据并只保留一条
为了避免改变原来的数据 ID,我们可以使用一个不同的方法,通过使用自连接来标记重复的数据并删除多余的记录。这种方法在保留原始 ID 的情况下删除重复记录。
假设你的表结构如下:
表名:your_table
列名:id (主键), column1, column2, 以及其他列。
你可以使用以下 SQL 语句来删除重复记录,只保留一条(通常是保留 ID 最小的那一条):
-- Step 1: 标记要删除的重复记录
DELETE t1
FROM your_table t1
INNER JOIN your_table t2
WHERE
t1.id > t2.id
AND t1.column1 = t2.column1
AND t1.column2 = t2.column2;
-- Step 2: 确认删除成功,查看剩余数据
SELECT * FROM your_table;
解释:
标记要删除的重复记录:我们使用自连接 INNER JOIN 来找到重复的记录,并且使用 WHERE t1.id > t2.id 来确保只删除 id 较大的记录,从而保留 id 最小的记录。
确认删除成功:通过 SELECT 语句查看剩余的数据,确保删除操作正确。
这个方法的优点是:
不会改变原始数据的 ID。
保留每组重复记录中 ID 最小的一条记录。
操作简单且高效。