oracle去重的四种方式

打印 上一主题 下一主题

主题 842|帖子 842|积分 2526

一、数据准备
  1. create table test15 (team int,id varchar2(20) ,name varchar2(20),sal number);
  2. insert into test15 values('1','张三','1000');
  3. insert into test15 values('2','李四','2000');
  4. insert into test15 values('2','李四','2000');
  5. insert into test15 values('3','赵六','3000');
  6. insert into test15 values('4','周七','6000');
  7. commit;
复制代码
二、去重方式先容
原表数据:

1、distinct
  1.  select distinct * from test15
复制代码

2、group by 没有聚合函数时,使用group by也能到达去重的效果
  1.  select  * from test15 group by team,name,sal
复制代码

3、rowid,oralce会为每一行记录创建一个独一无二的row_id,因此,我们可以按照主键分组,找到每个组的最小rowid,然后作为子查询进行筛选,如下:
  1. select * from test15 where rowid in(
  2. select  min(t.rowid) from  test15 t group by team)
复制代码

4、row_number() over(partition by ...  order by...  desc),使用over函数可以返回组内排序,我们可以按主键进行分组,然后按主键倒序排序,最后筛选出每个组的第一条,如下:
  1. select * from 
  2. (select t.*,row_number() over(partition by team order by team desc) rn from test15 t)
  3. where rn=1;
复制代码


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

悠扬随风

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表