初探oracle删除重复记录,只保留rowid最小的记录.docx
文本预览下载声明
初探oracle删除重复记录,只保留rowid最小的记录如题,初探oracle删除重复记录,只保留rowid最小的记录(rowid可以反映数据插入到数据库中的顺序)一、删除重复记录可以使用多种方法,如下只是介绍了两种方法(exist和in两种)。1.首先创建一个测试表。createtable my_users( id number, username varchar2(20), sal number)2.插入测试数据beginfor i in1..10 loopinsertinto my_users values(i,carl_zhang,i+10);end loop;end;beginfor i in1..10 loopinsertinto my_users values(i,carl_zhang,i+20);end loop;end;insertinto my_users values(100,carl,20.3);commit;3.查看重复记录select rowid,rownum,a.*from my_users awhere1=1andexists(selectexistfrom my_users bwhere1=1and a.id=b.idand a.username=b.usernamehavingcount(*)1)orderby rowid4.查看重复数据中,rowid最大的记录(rowid可以反映数据插入到数据库中的顺序)select rowid,rownum,a.*from my_users awhere1=1andexists(selectexistfrom my_users bwhere1=1and a.id=b.idand a.username=b.username-- having count(*)1havingcount(*)1and a.rowid=max(b.rowid))orderby rowid5.删除重复数据,保留rowid最小的记录deletefrom my_users awhere1=1andexists(selectexistfrom my_users bwhere1=1and a.id=b.idand a.username=b.username-- having count(*)1havingcount(*)1and a.rowid=max(b.rowid))二、以上方法是通过exist实现,相比in、not in更加的快速。1.如下,查看重复记录。select rowid,rownum,a.*from my_users awhere1=1and (a.id,a.username) in(select b.id,b.username from my_users bwhere1=1havingcount(*)1groupby b.id,b.username )orderby rowid2.查看重复数据中,rowid最大的记录select rowid,rownum,a.*from my_users awhere1=1and (a.id,a.username,rowid) in(select b.id,b.username,max(rowid) from my_users bwhere1=1havingcount(*)1groupby b.id,b.username )orderby rowid3.删除重复数据,保留rowid最小的记录deletefrom my_users awhere1=1and (a.id,a.username,rowid) in(select b.id,b.username,max(rowid) from my_users bwhere1=1havingcount(*)1groupby b.id,b.username )
显示全部