编程爱好者之家

mysql查询并删除一张表中两个字段重复方法

2023-11-14 14:52:12 16

mysql查询并删除一张表中两个字段重复方法。


1. 查找重复记录

首先,我们需要找到数据库表中的重复记录。可以使用以下 SQL 语句查询表中所有的重复记录:


SELECT column1, column2, COUNT(*) as count FROM table_name
GROUP BY column1, column2 HAVING COUNT(*) > 1;

其中,table_name 是需要查询的表名,column1 和 column2 是组成重复记录的字段。这条 SQL 语句会返回每组重复记录中 column1 和 column2 的值以及该组记录的重复次数 count。


2. 删除重复记录

找到重复记录后,我们需要将其删除,保留每组重复记录中的最小 id。可以使用以下 SQL 语句删除重复记录:


DELETE t1 FROM table_name t1
INNER JOIN (
SELECT MIN(id) AS min_id, column1, column2 FROM table_name
GROUP BY column1, column2 HAVING COUNT(*) > 1
) t2
ON t1.column1 = t2.column1 AND t1.column2 = t2.column2
WHERE t1.id > t2.min_id;

其中,table_name 是需要删除重复记录的表名,column1 和 column2 是组成重复记录的字段,id 是记录的唯一标识符。




同类文章