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 单表重新初始化同步的两种思路
4236 0
|
11月前
|
SQL Oracle 关系型数据库
Oracle 19c 补丁升级引发的单表恢复失败谜案
问题表现 某客户在恢复 Oracle 数据库的单表时,提示类似下面的信息
|
SQL 运维 分布式计算
单表七千六百万数据量(oracle)进行实时汇总,sql很慢客户不能忍一下,该怎么办?
单表七千六百万数据量(oracle)进行实时汇总,sql很慢客户不能忍一下,该怎么办?
224 0
单表七千六百万数据量(oracle)进行实时汇总,sql很慢客户不能忍一下,该怎么办?
|
Oracle 关系型数据库 数据库
Oracle-单表查询
关于单张表的操作(分组、排序、条件查询、函数)
1194 0
|
SQL Oracle 关系型数据库
【Oracle】单表的选择率
  本文只是记录《基于成本的oracle 优化法则》的简单的笔记(因为要重新搭建RAC 把之前的环境删掉了,oracle 环境还没建好,现在先纸上谈兵一下 ) 优化器并没有智能--只是一个软件! 1 对含有空值的字段  基本选择率=1/num...
1033 0
|
15天前
|
SQL Oracle 关系型数据库
【Oracle】玩转Oracle数据库(一):装上去,飞起来!
【Oracle】玩转Oracle数据库(一):装上去,飞起来!
56 7
|
1月前
|
Oracle 关系型数据库 数据库
|
1月前
|
Oracle 关系型数据库 数据库
Oracle数据库基本概念理解(3)
Oracle数据库基本概念理解(3)
18 2
|
15天前
|
SQL Oracle 关系型数据库
【Oracle】玩转Oracle数据库(七):RMAN恢复管理器
【Oracle】玩转Oracle数据库(七):RMAN恢复管理器
41 5

推荐镜像

更多