RANK()
说明:返回结果集的分区内每行的排名。行的排名是相关行之前的排名数加一。
语法:RANK () OVER ( [ < partition_by_clause > ] < order_by_clause > )
备注:如果两个或多个行与一个排名关联,则每个关联行将得到相同的排名。
例如,如果两位顶尖销售员具有同样的 SalesTD 值,他们将并列第一。
由于已有两行排名在前,所以具有下一个最大SalesTD 的销售人员将排名第三。
因此,RANK 函数并不总返回连续整数。
用于整个查询的排序顺序决定了行在结果集中的显示顺序。这也隐含了行在每个分区中的排名。
参数:< partition_by_clause > :将 FROM 子句生成的结果集划分为要应用 RANK 函数的分区。
< order_by_clause >:确定将 RANK 值应用于分区中的行时所基于的顺序。
返回类型:bigint
通过RANK函数,查询出各个部门(department_ID)的前3名的得分(score_ID)
SELECT * FROM
(SELECT score_ID,department_ID,
RANK () OVER (PARTITION BY department_ID ORDER BY score_ID DESC) AS RANK
FROM OutputRankingSummary) A
WHERE A.RANK<=3
WHERE A.RANK<=3