ORACLE 去重的四种方式

一、数据准备

create table test15 (team int,id varchar2(20) ,name varchar2(20),sal number);
 insert into test15 values('1','张三','1000');
 insert into test15 values('2','李四','2000');
 insert into test15 values('2','李四','2000');
 insert into test15 values('3','赵六','3000');
 insert into test15 values('4','周七','6000');
 commit;

二、去重方式介绍
原表数据:
在这里插入图片描述
1、distinct

 select distinct * from test15

在这里插入图片描述
2、group by 没有聚合函数时,使用group by也能达到去重的效果

 select  * from test15 group by team,name,sal

在这里插入图片描述
3、rowid,oralce会为每一行记录创建一个独一无二的row_id,因此,我们可以按照主键分组,找到每个组的最小rowid,然后作为子查询进行筛选,如下:

select * from test15 where rowid in(
select  min(t.rowid) from  test15 t group by team)

在这里插入图片描述
4、row_number() over(partition by … order by… desc),使用over函数可以返回组内排序,我们可以按主键进行分组,然后按主键倒序排序,最后筛选出每个组的第一条,如下:

select * from 
(select t.*,row_number() over(partition by team order by team desc) rn from test15 t)
where rn=1;

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值