码迷,mamicode.com
首页 > 数据库 > 详细

oracle中分组排序取TOP n

时间:2015-05-26 18:17:09      阅读:688      评论:0      收藏:0      [点我收藏+]

标签:

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

标签:

原文地址:http://www.cnblogs.com/nicoleyaya/p/4530785.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!