mysql对重复数据操作

前言

最近对数据库进行复习这篇文章也只是记录一些遇到到问题,并记录解决方法。

查找表(Demo)中多余的重复记录,重复记录是根据单个字段(name)来判断

select * from Demo01 where name in 
(select name from Demo group by name having count(name) > 1);

删除表(Demo)中多余的重复记录,重复记录是根据单个字段(name)来判断,只留有id最小的记录

delete from Demo where 
name in (select name from Demo group by name   having count(name) > 1) and 
id not in (select min(id) from Demo group by name having count(name )>1);

查找表(Demo)中多余的重复记录(多个字段 )

select * from Demo a where
(a.name,a.age) in
(select name,age from Demo group by name,age having count(*) > 1);

查找表(Demo)中多余的重复记录(多个字段),不包含id最小的记录

select * from Demo a where 
(a.name,a.age) in (select name,age from Demo group by 
name,age having count(*) > 1) and
id not in (select min(id) from Demo group by name,age having count(*)>1);

仅供参考,希望自己的分享帮助有需要的人。

posted @ 2021-07-13 10:50  Tireless  阅读(68)  评论(0编辑  收藏  举报