好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

实例讲解sql server排名函数DENSE_RANK的用法

一、需求

  之前sql server 的排名函数用得最多的应该是RoW_NUMBER()了,我通常用ROW_NUMBER() + CTE 来实现分页;今天逛园,看到另一个 python 内置排名函数还不错,自己顺便想了一个需求,大家可以花1分钟先想想要怎么实现。

  需求很简单:求成绩排名前五的学生信息。

  例如:

  

  由于成绩可以并列,所以前五名可能有多个。例如:

    

  测试数据:  

declare @t table
(ID int,
 StudentName nvarchar(15),
 Score int)
 
insert into @t
select 1,'黄一',99 union all
select 2,'吴二',99 union all
select 3,'张三',99 unio  php  n all
select 4,'李四',98 union all
select 5,'王五',97 union all
sehttp://HdhCmsTestcppcns测试数据lect 6,'赵六',96 union all
select 7,'田七',95 union all
se  编程客栈  lect 8,'纪八',94 union all
select 9,'邱九',93 union all
select 10,'林十',92 

二、自己实现

  我的想法:既然可能出现并列,那么就用 DISTINCT 找到前五的成绩。ok,代码如下:

javascript

select t1.* from @t t1
join(select distinct top 5 Score from @t order by Score desc) t2
on 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的使用方法,分享了自己的一些想法,希望对大家的学习有所启发。

查看更多关于实例讲解sql server排名函数DENSE_RANK的用法的详细内容...

  阅读:27次