好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

oracle中分组排序取TOP n

数据库中数据处理时,经常需要对某一类的数据取Top n,这就涉及到分组group by 并排序 order by ,之后根据rownum获取前几名数据,oracle数据库中ROW_NUMBER() OVER函数可以实现这个功能,如下:

/*获取tab_a表中每个省份counts最大的前10个kpi*/
SELECT *
FROM (SELECT ROW_NUMBER() OVER(PARTITION BY prov ORDER BY counts DESC) rn,
prov,
kpi,
counts
FROM tab_a a)
WHERE rn < 10

oracle中分组排序取TOP n

标签:

查看更多关于oracle中分组排序取TOP n的详细内容...

  阅读:33次