这篇文章将为大家详细讲解有关sql server排名函数DENSE_RANK的用法是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

一、需求

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

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

  例如:

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

  测试数据:  

declare@ttable(IDint,StudentNamenvarchar(15),Scoreint)insertinto@tselect1,'黄一',99unionallselect2,'吴二',99unionallselect3,'张三',99unionallselect4,'李四',98unionallselect5,'王五',97unionallselect6,'赵六',96unionallselect7,'田七',95unionallselect8,'纪八',94unionallselect9,'邱九',93unionallselect10,'林十',92 

二、自己实现

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

selectt1.*from@tt1join(selectdistincttop5Scorefrom@torderbyScoredesc)t2ont1.Score=t2.Score    

  看起来和上面的要求的结果还是不太一样,少了排序,当然我们可以在程序处理,这不是问题。

三、使用内置排名函数 DENSE_RANK

  其实sql server已经内置了这样的函数可以帮助我们轻松实现,ok,直接上代码:

;withcteas(selectdense_rank()over(orderbyScoredesc)rank,*from@t)select*fromctewhererank<6  

四、扩展,内置排名函数RANK

  与 DENSE_RANK类似还有一个RANK函数,不过RANK函数不会顺序排名,而是根据序号排。有点绕,把上面的函数改为RANK()就知道了。

关于sql server排名函数DENSE_RANK的用法是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。