转载自:http://www.csdn.net/article/1970-01-01/278287

平时工作中可能会遇到当试图对库表中的某一列或几列创建唯一索引时,系统提示 ORA-01452 :不能创建唯一索引,发现重复记录。

下面总结一下几种查找和删除重复记录的方法(以表CZ为例):

表CZ的结构如下:

SQL> desc cz   Name Null? Type   -------------------------------------------------------------------   C1 NUMBER(10)   C10 NUMBER(5)   C20 VARCHAR2(3) 

删除重复记录的方法原理:

(1).在Oracle中,每一条记录都有一个rowid,rowid在整个数据库中是唯一的,rowid确定了每条记录是在Oracle中的哪一个数据文件、块、行上。

(2).在重复的记录中,可能所有列的内容都相同,但rowid不会相同,所以只要确定出重复记录中那些具有最大rowid的就可以了,其余全部删除。

重复记录判断的标准是:

C1,C10和C20这三列的值都相同才算是重复记录。

经查看表CZ总共有16条记录:

SQL>set pagesize 100   SQL>select * from cz;   C1 C10 C20   ---------- ---------- ---   1 2 dsf   1 2 dsf   1 2 dsf   1 2 dsf   2 3 che   1 2 dsf   1 2 dsf   1 2 dsf   1 2 dsf   2 3 che   2 3 che   2 3 che   2 3 che   3 4 dff   3 4 dff   3 4 dff   4 5 err   5 3 dar   6 1 wee   7 2 zxc   20 rows selected. 

1.查找重复记录的几种方法:

(1).SQL>select * from cz group by c1,c10,c20 having count(*) >1;

C1 C10 C20
-----------------------
1 2 dsf
2 3 che
3 4 dff 

(2).SQL>select distinct * from cz;

C1 C10 C20
-----------------------
1 2 dsf
2 3 che
3 4 dff 

(3).SQL>select * from cz a where rowid=(select max(rowid) from cz where c1=a.c1 and c10=a.c10 and c20=a.c20);

C1 C10 C20
-----------------------
1 2 dsf
2 3 che
3 4 dff 

2.删除重复记录的几种方法:

(1).适用于有大量重复记录的情况(在C1,C10和C20列上建有索引的时候,用以下语句效率会很高):

SQL>delete from cz where (c1,c10,c20) in (select c1,c10,c20 from cz group by c1,c10,c20 having count(*)>1) and rowid not in   (select min(rowid) from cz group by c1,c10,c20 having count(*)>1);
SQL>delete from cz where rowid not in(select min(rowid) from cz group by c1,c10,c20); 

(2).适用于有少量重复记录的情况(注意,对于有大量重复记录的情况,用以下语句效率会很低):

SQL>delete from cz a where a.rowid!=(select max(rowid) from cz b where a.c1=b.c1 and a.c10=b.c10 and a.c20=b.c20);
SQL>delete from cz a where a.rowid<(select max(rowid) from cz b where a.c1=b.c1 and a.c10=b.c10 and a.c20=b.c20);
SQL>delete from cz a where a.rowid <(select max(rowid) from cz where c1=a.c1 and c10=a.c10 and c20=a.c20); 

(3).适用于有少量重复记录的情况(临时表法):

SQL>create table test as select distinct * from cz; (建一个临时表test用来存放重复的记录)SQL>truncate table cz; (清空cz表的数据,但保留cz表的结构)SQL>insert into cz select * from test; (再将临时表test里的内容反插回来)

Oracle几种查找和删除重复记录的方法总结相关推荐

  1. oracle 视图去重复,CSS_Oracle几种查找和删除重复记录的方法总结,平时工作中可能会遇到当试图 - phpStudy...

    Oracle几种查找和删除重复记录的方法总结 平时工作中可能会遇到当试图对库表中的某一列或几列创建唯一索引时,系统提示 ORA-01452 :不能创建唯一索引,发现重复记录. 下面总结一下几种查找和删 ...

  2. oracle如何快速查找,Oracle 如何快速查找和删除重复记录

    今天整理用户系统的人员库,发现有很多人员有重复,需要删除掉这些冗余的人员信息:在网上查了一下,基本上有两种解决办法: 在Oracle中,每一条记录都有一个rowid,rowid在整个数据库中是唯一的, ...

  3. Oracle数据库删除重复记录的方法

    Oracle数据库删除重复记录的方法,做项目的时候,一位同事导数据的时候,不小心把一个表中的数据全都搞重了,也就是说,这个表里所有的记录都有一条重复的.这个表的数据是千万级的,而且是生产系统.也就是说 ...

  4. access重复数据累计_在 Access 中查找并删除重复记录

    如果您的 Access 数据库包含从多个源导入的数据,或者您继承了已经使用多年而且没有得到正确设置的数据库,那么该数据库中可能包含需要清除的重复记录. 要确定 Access 表中是否存在重复记录,可以 ...

  5. mysql删除重复文章标题_MySQL中查询、删除重复记录的方法大全

    前言 本文主要给大家介绍了关于MySQL中查询.删除重复记录的方法,分享出来供大家参考学习,下面来看看详细的介绍: 查找所有重复标题的记录: 一.查找重复记录 1.查找全部重复记录 2.过滤重复记录( ...

  6. mysql去掉两个最高分_MySQL中查询、删除重复记录的方法大全

    前言 本文主要给大家介绍了关于MySQL中查询.删除重复记录的方法,分享出来供大家参考学习,下面来看看详细的介绍: 查找所有重复标题的记录: select title,count(*) as coun ...

  7. java重复录入怎么删除,删除重复记录的方法

    学习sql有一段时间了,发现在我建了一个用来测试的表(没有建索引)中出现了许多的重复记录.后来总结了一些删除重复记录的方法,在Oracle中,可以通过唯一rowid实现删除重复记录:还可以建临时表来实 ...

  8. 在SQL中删除重复记录(多种方法) [转]

    学习sql有一段时间了,发现在我建了一个用来测试的表(没有建索引)中出现了许多的重复记录.后来总结了一些删除重复记录的方法,在Oracle中,可以通过唯一rowid实现删除重复记录:还可以建临时表来实 ...

  9. MySQL查询重复字段,及删除重复记录的方法

    MySQL查询重复字段,及删除重复记录的方法(转) Submitted by wiley on Thu, 09/03/2009 - 09:36 [教学] MySQL查询重复字段,及删除重复记录的方法 ...

最新文章

  1. react前端开发_是的,React正在接管前端开发。 问题是为什么。
  2. 神经网络原来是这样和数学挂钩的
  3. Java 寻找幸运数
  4. Ie6下asp.net 中treeview自动随鼠标变小的修复
  5. 基于分层注意力网络的方面情感分析
  6. UVA - 10603 Fill(隐式图搜索)
  7. outermost shell_outermost是什么意思_outermost的翻译_音标_读音_用法_例句_爱词霸在线词典...
  8. 安卓开发-开发环境搭建
  9. 扩散模型 (Diffusion Model) 简要介绍与源码分析
  10. MSF evasion模块的使用
  11. python mqtt publish_mqtt异步publish方法
  12. 简单好用的Linux服务器管理面板——宝塔面板
  13. 【java毕业设计】基于javaEE+SSH+mysql的医院在线挂号系统设计与实现(毕业论文+程序源码)——医院在线挂号系统
  14. 如何提高程序员键盘使用效率
  15. 李学斌:论复杂系统中的应用间协作V3
  16. 红米手机开发版怎么样获取ROOT权限
  17. mysql cast()与convert() 函数
  18. 事务隔离级别——未提交读、已提交读、可重复读、串行
  19. 那么问题来了? int(a/b) 和 a//b 的区别在哪里呢? 例1:
  20. 如何删除下一页分节符_页面布局里分节符添加的下一页空白页怎么删 - 卡饭网...

热门文章

  1. vue中style的scoped属性的设计方式
  2. QT在Ubuntu18中persisting cmake state
  3. GPC:使用GPC计算intersection容易出现的问题
  4. 使用std::cout不能输出显示
  5. 统计之都 http://cos.name/
  6. deeplearning4j – 分布式DL开源项目
  7. 在WordPress中添加简书风格的连载目录和文章导航...
  8. 某电视台晚会多机位特殊视频修复案例
  9. 1月17日学习内容整理:Scrapy框架补充之pipeline,去重规则
  10. 【网络编程】用Socket实现聊天小程序