排序函数 dense_rank()

dense_rank()

对结果集进行排序,排名值没有间断。 特定行的排名等于该特定行之前不同排名值的数量加一。

语法:

DENSE_RANK ( ) OVER ( [ <partition_by_clause> ] < order_by_clause > )  

PARTITION BY 分组, ORDER BY 排序

举例:学生成绩表如下:
排序函数 dense_rank()_第1张图片
利用dense_rank(),按每门课程成绩的高低进行排序,sql如下:

select dense_rank() over(partition by gc_no order by gs_scoure desc )a, * from test.[dbo].[grade]

结果如下:
排序函数 dense_rank()_第2张图片
从上述执行结果可以看出:
函数和rank()函数的相同点在于相同的成绩排名相同,区别在于,之后的排序rank()是不连续的,dense_rank()是连续的。

你可能感兴趣的:(SQL,sql)