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 单表重新初始化同步的两种思路
4406 0
|
SQL Oracle 关系型数据库
Oracle 19c 补丁升级引发的单表恢复失败谜案
问题表现 某客户在恢复 Oracle 数据库的单表时,提示类似下面的信息
131 0
|
SQL 运维 分布式计算
单表七千六百万数据量(oracle)进行实时汇总,sql很慢客户不能忍一下,该怎么办?
单表七千六百万数据量(oracle)进行实时汇总,sql很慢客户不能忍一下,该怎么办?
273 0
单表七千六百万数据量(oracle)进行实时汇总,sql很慢客户不能忍一下,该怎么办?
|
Oracle 关系型数据库 数据库
Oracle-单表查询
关于单张表的操作(分组、排序、条件查询、函数)
1230 0
|
SQL Oracle 关系型数据库
【Oracle】单表的选择率
  本文只是记录《基于成本的oracle 优化法则》的简单的笔记(因为要重新搭建RAC 把之前的环境删掉了,oracle 环境还没建好,现在先纸上谈兵一下 ) 优化器并没有智能--只是一个软件! 1 对含有空值的字段  基本选择率=1/num...
1055 0
|
2天前
|
存储 Oracle 关系型数据库
Oracle数据库的应用场景有哪些?
【10月更文挑战第15天】Oracle数据库的应用场景有哪些?
94 64
|
1天前
|
监控 Oracle 关系型数据库
Oracle数据库性能优化
【10月更文挑战第16天】Oracle数据库性能优化是
5 1
|
14天前
|
SQL 存储 Oracle
Oracle数据库SQL语句详解与应用指南
在数字化时代,数据库已成为各类企业和组织不可或缺的核心组件。Oracle数据库作为业界领先的数据库管理系统之一,广泛应用于各种业务场景。掌握Oracle数据库的SQL语句是数据库管理员、开发人员及运维人员的基本技能。本文将详细介绍Oracle数据库SQL语句的基本概念、语法、应用及最佳实践。一、Or
28 3
|
1月前
|
Oracle 关系型数据库 数据库
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
打开oracle数据库报错“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。 数据库没有备份,无法通过备份去恢复数据库。用户方联系北亚企安数据恢复中心并提供Oracle_Home目录中的所有文件,急需恢复zxfg用户下的数据。 出现“system01.dbf需要更多的恢复来保持一致性”这个报错的原因可能是控制文件损坏、数据文件损坏,数据文件与控制文件的SCN不一致等。数据库恢复工程师对数据库文件进一步检测、分析后,发现sysaux01.dbf文件损坏,有坏块。 修复并启动数据库后仍然有许多查询报错,export和data pump工具使用报错。从数据库层面无法修复数据库。
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例

推荐镜像

更多