初探oracle删除重复记录,只保留rowid最小的记录.docx

初探oracle删除重复记录,只保留rowid最小的记录.docx

  1. 1、本文档共3页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
初探oracle删除重复记录,只保留rowid最小的记录

初探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 )

文档评论(0)

2017ll + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档