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
 

注:學習共勉

有不清楚的都可以問我哈^_^

希望各位IT男和IT女也關注一下我的副業,水果https://shop247384222.taobao.com/?spm=a230r.7195193.1997079397.2.YaXEih 批發價


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM