一、需求
之前sql server 的排名函数用得最多的应该是RoW_NUMBER()了,我通常用ROW_NUMBER() + CTE 来实现分页;今天逛园,看到另一个内置排名函数还不错,自己顺便想了一个需求,大家可以花1分钟先想想要怎么实现。
需求很简单:求成绩排名前五的学生信息。
例如:
由于成绩可以并列,所以前五名可能有多个。例如:
测试数据:
declare @t table(ID int, StudentName nvarchar(15), Score int) insert into @tselect 1,'黄一',99 union allselect 2,'吴二',99 union allselect 3,'张三',99 union allselect 4,'李四',98 union allselect 5,'王五',97 union allselect 6,'赵六',96 union allselect 7,'田七',95 union allselect 8,'纪八',94 union allselect 9,'邱九',93 union allselect 10,'林十',92二、自己实现
我的想法:既然可能出现并列,那么就用 DISTINCT 找到前五的成绩。ok,代码如下:
select t1.* from @t t1join(select distinct top 5 Score from @t order by Score desc) t2on t1.Score = t2.Score看起来和上面的要求的结果还是不太一样,少了排序,当然我们可以在程序处理,这不是问题。
三、使用内置排名函数 DENSE_RANK
其实sql server已经内置了这样的函数可以帮助我们轻松实现,ok,直接上代码:
;with cte as( select dense_rank() over(order by Score desc) rank,* from @t)select * from cte where rank < 6四、扩展,内置排名函数RANK
与 DENSE_RANK类似还有一个RANK函数,不过RANK函数不会顺序排名,而是根据序号排。有点绕,把上面的函数改为RANK()就知道了,得到的结果如下:
以上就是sql server排名函数DENSE_RANK的使用方法,分享了自己的一些想法,希望对大家的学习有所启发。