Oracle单表去重

简介:
去重有两层含义,一是记录完全一样。而是符合一定条件的认为是重复。
 
根据表的数量,去重可划分为单表去重和多表关联去重。
 
对于去重,一般最容易想到的是用distinct,而distinct只能对完全重复的记录保留一条。distinct使用的是二重循环来去重的,如果数据量非常大的时候,会导致性能急剧下降。
 
下面是一个单表去重的测试,认为name字段相同的即为重复记录,要查询出一个结果,过滤掉重复,distinct显然不能满足要求。
 
表SQL:
create  table A_TEST    
(    
        id                 number,    
         name         varchar2(20),    
        remark varchar2(20)    
);    

insert  into A_TEST (ID,  NAME, REMARK)    
values (1,  'a''ss');    

insert  into A_TEST (ID,  NAME, REMARK)    
values (2,  'b''xxx');    

insert  into A_TEST (ID,  NAME, REMARK)    
values (3,  'b''x');    

insert  into A_TEST (ID,  NAME, REMARK)    
values (4,  'b''asd');    

insert  into A_TEST (ID,  NAME, REMARK)    
values (5,  'c''axxx');    

insert  into A_TEST (ID,  NAME, REMARK)    
values (6,  'c''asdf');    
 
 
去重方式一(低效):
select a.*    
         from A_TEST a, ( select  min(id)  as id  from A_TEST t  group  by  name) b    
where a.id = b.id;
 

去重方式一(高效):
select *    
         from ( select a.*, rownum row_num  from A_TEST a) x    
where x.row_num  in ( select  min(rownum)  from A_TEST t  group  by  name)
 
 
可见,使用rownum的效率比使用id的效率要高,当表数据量很大的时候,差距会很明显。


本文转自 leizhimin 51CTO博客,原文链接:http://blog.51cto.com/lavasoft/368087,如需转载请自行联系原作者
相关文章
|
Oracle 关系型数据库
Oracle OGG 单表重新初始化同步的两种思路
OGG 单表重新初始化同步的两种思路
4449 0
|
SQL Oracle 关系型数据库
Oracle 19c 补丁升级引发的单表恢复失败谜案
问题表现 某客户在恢复 Oracle 数据库的单表时,提示类似下面的信息
143 0
|
SQL 运维 分布式计算
单表七千六百万数据量(oracle)进行实时汇总,sql很慢客户不能忍一下,该怎么办?
单表七千六百万数据量(oracle)进行实时汇总,sql很慢客户不能忍一下,该怎么办?
291 0
单表七千六百万数据量(oracle)进行实时汇总,sql很慢客户不能忍一下,该怎么办?
|
Oracle 关系型数据库 数据库
Oracle-单表查询
关于单张表的操作(分组、排序、条件查询、函数)
1241 0
|
SQL Oracle 关系型数据库
【Oracle】单表的选择率
  本文只是记录《基于成本的oracle 优化法则》的简单的笔记(因为要重新搭建RAC 把之前的环境删掉了,oracle 环境还没建好,现在先纸上谈兵一下 ) 优化器并没有智能--只是一个软件! 1 对含有空值的字段  基本选择率=1/num...
1063 0
|
3月前
|
存储 Oracle 关系型数据库
Oracle数据库的应用场景有哪些?
【10月更文挑战第15天】Oracle数据库的应用场景有哪些?
225 64
|
27天前
|
存储 Oracle 关系型数据库
数据库数据恢复—ORACLE常见故障的数据恢复方案
Oracle数据库常见故障表现: 1、ORACLE数据库无法启动或无法正常工作。 2、ORACLE ASM存储破坏。 3、ORACLE数据文件丢失。 4、ORACLE数据文件部分损坏。 5、ORACLE DUMP文件损坏。
86 11
|
2月前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—Oracle数据库文件有坏快损坏的数据恢复案例
一台Oracle数据库打开报错,报错信息: “system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。管理员联系我们数据恢复中心寻求帮助,并提供了Oracle_Home目录的所有文件。用户方要求恢复zxfg用户下的数据。 由于数据库没有备份,无法通过备份去恢复数据库。
|
2月前
|
存储 Oracle 关系型数据库
oracle数据恢复—Oracle数据库文件大小变为0kb的数据恢复案例
存储掉盘超过上限,lun无法识别。管理员重组存储的位图信息并导出lun,发现linux操作系统上部署的oracle数据库中有上百个数据文件的大小变为0kb。数据库的大小缩水了80%以上。 取出&并分析oracle数据库的控制文件。重组存储位图信息,重新导出控制文件中记录的数据文件,发现这些文件的大小依然为0kb。

推荐镜像

更多