前提条件:本文以postgresql为准。
RANK 每个值一个排名,同样的值排同样的位置,如第一名有2个,下一个值就要排第三,如此类推,表现如下面的 RandNr 列DENSE_RANK 每个值一个排名,跟Rank 不一致的地方在于它不跳号,会1,2,3 那样排下来ROW_NUMBER 每行一个排序值,遇到相同的排序条件的时候,按照顺序给值,对应表现如下面RowNr 列
建表:
执行sql:
SELECT RANK() OVER (ORDER BY s_score desc) AS RankNr,
DENSE_RANK() OVER (ORDER BY s_score desc ) AS DenseNr,
ROW_NUMBER() OVER (ORDER BY s_score desc) AS RowNr,
*
FROM student_score ss where s_subject ='english';
结果:
分别判断英语、数学的成绩排名:
select ROW_NUMBER() OVER
(partition by s_subject ORDER BY s_score desc ) AS DenseNr,*
from student_score;
结果:
附加:
Over 子句:
Over(
Partition By AAA,BBB --表示按照AAA,BBB进行分组,每个分组从1开始计数,如果忽略 Partition By 关键字,就当整个结果集作为一个分组来排序
Order by CCC asc,DDD desc --表示按照ccc,ddd 的执行排序赋予排序值,如果没有特定的排序顺序怎么办呢? 可以使用 (select 1) 或者用 newid() 这个就用于随机排序用的
)
partition by 用于结果集分组,如果没有指定,会把整个结果集作为一个分组
rank 、dense_rank 、row_numer 都是不同方式的结果集组内排序,一般都结合over 字句出现,over 字句里 会有 partition by、order by、last、first 的任意组合,如下:
rank() over(partition by a,b order by a, order by b desc);
rank() over(partition by a order by b nulls first)
rank() over(partition by a order by b nulls last)