ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

ORACLE分组排序后获取第一条和最后一条值

2021-11-17 15:04:28  阅读:226  来源: 互联网

标签:name PARTITION 第一条 t1 分组 ORACLE 排序 id


Oracle数据库,分组排序后取第一条数据

数据格式

 分组取第一条的效果

SELECT *       
    FROM (SELECT ROW_NUMBER() OVER(PARTITION BY x ORDER BY y DESC) rn,       
          test1.*       
          FROM test1)       
   WHERE rn = 1  ;   
Oracle数据库,分组排序后取第一条数据和最后一条,并且拼接名称
select id,wm_concat(name) as qsgt from (
  select id,name from (-- 分组排序取出第一条和最后一条
    select
    t1.id,
    t1.name,
    row_number() over(PARTITION BY t1.id order by t1.name) rowss1,--第一条
    row_number() over(PARTITION BY t1.id order by t1.name desc) rowss2--倒数第一条
    from t_test t1
    where t1.pid= '0'
  )
  where rowss1='1' or rowss2='1'
) GROUP BY id

 不分组的话去掉    

PARTITION BY t1.id 

 就行

标签:name,PARTITION,第一条,t1,分组,ORACLE,排序,id
来源: https://www.cnblogs.com/h-c-g/p/15567294.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有