zoukankan      html  css  js  c++  java
  • ORACLE分组排序后获取第一条和最后一条值

    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 

     就行

  • 相关阅读:
    Jmeter之Bean shell使用(一)
    CSS知识点 2
    0523 CSS知识点
    0522 HTML表单 CSS基础
    0521 HTML基础
    0515线程
    0514 队列 管道 进程池 回调函数
    0510进程 multiprocess模块
    0509操作系统发展史 进程
    0507黏包
  • 原文地址:https://www.cnblogs.com/h-c-g/p/15567294.html
Copyright © 2011-2022 走看看