sql-server – 将结果限制为前2个排名行
发布时间:2021-05-22 07:03:03 所属栏目:MsSql教程 来源:网络整理
导读:在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
在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()将原始查询放入子查询中,并使用筛选结果的查询对其进行包装.(编辑:扬州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- SQL Oracle排序字符串(数字)和(带数字的字母)
- 在sql中找到同一个表中两个连续行之间的时间差
- sql存储过程有何好处?怎样创建和使用?
- sql – Postgres:选择具有大于1的字段数的所有行
- sql-server – 在不返回任何行的查询中包含ORDER BY会严重影
- sql-server – 如何以非弃用的方式从VBA访问SQL Server?
- sql-server-2008 – 通过存储过程模拟TSQL序列
- jwt – Keycloak从数据库/外部源添加额外声明
- sql – 确定nvarchar列中的varchar内容
- sql-server – SQL Server CASE语句是否评估所有条件或在第
站长推荐
热点阅读