最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Oracle查询删除表中重复记录

来源:动视网 责编:小采 时间:2020-11-09 11:57:10
文档

Oracle查询删除表中重复记录

Oracle查询删除表中重复记录:最高效删除重复记录的方法,使用为例rowid DELETE FROM EMP E WHERE E.ROWID gt; (SELECT MIN(X.ROWID) FROM EMP X WHERE X.EMP 最高效删除重复记录的方法,使用为例rowid DELETE FROM EMP E WHERE E.ROWID > (S
推荐度:
导读Oracle查询删除表中重复记录:最高效删除重复记录的方法,使用为例rowid DELETE FROM EMP E WHERE E.ROWID gt; (SELECT MIN(X.ROWID) FROM EMP X WHERE X.EMP 最高效删除重复记录的方法,使用为例rowid DELETE FROM EMP E WHERE E.ROWID > (S


最高效删除重复记录的方法,使用为例rowid DELETE FROM EMP E WHERE E.ROWID gt; (SELECT MIN(X.ROWID) FROM EMP X WHERE X.EMP

最高效删除重复记录的方法,使用为例rowid

DELETE FROM EMP E WHERE E.ROWID > (SELECT MIN(X.ROWID) FROM EMP X WHERE X.EMP_NO = E.EMP_NO);

1、查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断
  select * from people
  where peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1)
  2、删除表中多余的重复记录,,重复记录是根据单个字段(peopleId)来判断,只留有 rowid最小的记录
  delete from people
  where peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1)
  and rowid not in (select min(rowid) from people group by peopleId having count(peopleId )>1)
  注:rowid为Oracle自带不用该.....
  3、查找表中多余的重复记录(多个字段)
  select * from vitae a
  where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
  4、删除表中多余的重复记录(多个字段),只留有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)
  5、查找表中多余的重复记录(多个字段),不包含rowid最小的记录
  select * 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)
  (二)
  比方说
  在A表中存在一个字段“name”,
  而且不同记录之间的“name”值有可能会相同,
  现在就是需要查询出在该表中的各记录之间,“name”值存在重复的项;
  Select Name,Count(*) From A Group By Name Having Count(*) > 1
  如果还查性别也相同大则如下:
  Select Name,sex,Count(*) From A Group By Name,sex Having Count(*) > 1

文档

Oracle查询删除表中重复记录

Oracle查询删除表中重复记录:最高效删除重复记录的方法,使用为例rowid DELETE FROM EMP E WHERE E.ROWID gt; (SELECT MIN(X.ROWID) FROM EMP X WHERE X.EMP 最高效删除重复记录的方法,使用为例rowid DELETE FROM EMP E WHERE E.ROWID > (S
推荐度:
标签: 删除 查询 记录
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top