当前位置:Gxlcms > 数据库问题 > oracle中分组排序取TOP n

oracle中分组排序取TOP n

时间:2021-07-01 10:21:17 帮助过:7人阅读

数据库中数据处理时,经常需要对某一类的数据取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

标签:

人气教程排行