sql-server – 将功效限定为前2个排名行
发布时间:2021-05-20 14:16:28 所属栏目:编程 来源:网络整理
导读:在SQL Server 2008中,我行使RANK()OVER(PARTITION BY Col2 ORDER BY Col3 DESC)来返回带有RANK的数据集.可是我为每个分区都稀有百笔记录,因此我将得到1,2,3 …… 999品级的值.可是我想在每个PARTITION中最多只有2个RANK. 例: ID Name Score Subject1 Joe 100
在SQL Server 2008中,我行使RANK()OVER(PARTITION BY Col2 ORDER BY Col3 DESC)来返回带有RANK的数据集.可是我为每个分区都稀有百笔记录,因此我将得到1,2,3 …… 999品级的值.可是我想在每个PARTITION中最多只有2个RANK. 例: ID Name Score Subject 1 Joe 100 Math 2 Jim 99 Math 3 Tim 98 Math 4 Joe 99 History 5 Jim 100 History 6 Tim 89 History 7 Joe 80 Geography 8 Tim 100 Geography 9 Jim 99 Geography 我但愿功效如下: SELECT Subject,Name,RANK() OVER (PARTITION BY Subject ORDER BY Score DESC) FROM Table Subject Name Rank Math Joe 1 Math Jim 2 History Jim 1 History Joe 2 Geography Tim 1 Geography Jim 2 我只想在每个种别中排名第1和第2.我该怎么做呢? 办理要领您可以行使rank()将原始查询放入子查询中,并行使筛选功效的查询对其举办包装.(编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
站长推荐
热点阅读