MySQL 查询重复的数据,以及部分字段去重和彻底去重

1 、查找表中多余的重复记录(多个字段)
select * from vitae a
where (a.peopleId,a.seq) in 
(select peopleId,seq from vitae group by peopleId,seq having count(*)> 1 )
 
2 、删除表中多余的重复记录(多个字段),只留有rowid最小的记录
delete from vitae a
where 
(a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq 
having count(*) >  1 )
and rowid not in (select min(rowid) from vitae group 
by peopleId,seq having count(*)> 1 )
 
上面是部分字段去重
而彻底相同的去重相对简单些,方法以下
select distinct * into Tmp from tableName
drop table tableName
select * into tableName from Tmp
drop table Tmp
 

注:学习共勉java

有不清楚的均可以问我哈^_^学习

但愿各位IT男和IT女也关注一下个人副业,水果https://shop247384222.taobao.com/?spm=a230r.7195193.1997079397.2.YaXEih 批发价spa

相关文章
相关标签/搜索