sql-server – 将结果限制为前2个排名行
发布时间:2021-05-21 10:34:24 所属栏目: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中,它是复合键还是复合键?
- sql-server – SQL Server如何确定缺失索引请求中的键列顺序
- insert select与select into 的用法使用步骤
- sql-server – 在我的本地计算机上通过SQL Server Manageme
- sql-server – 执行计划与STATISTICS IO订单
- 浅谈简单的sql查询语句,你都知道哪些?
- sql – 按日期分组,即使没有找到记录也返回行
- @OrderBy导致java.lang.ClassCastException:antlr.CommonT
- sql-server – 找出导致最大网络流量的查询
- sql – 具有Desc / Asc排序的Order By子句的Case语句
站长推荐
热点阅读