sql server排名函数DENSE_RANK的用法是什么
发表于:2025-11-09 作者:千家信息网编辑
千家信息网最后更新 2025年11月09日,这篇文章将为大家详细讲解有关sql server排名函数DENSE_RANK的用法是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、需求之前sq
千家信息网最后更新 2025年11月09日sql server排名函数DENSE_RANK的用法是什么
这篇文章将为大家详细讲解有关sql server排名函数DENSE_RANK的用法是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
一、需求
之前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的用法是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
函数
成绩
需求
不错
代码
内容
文章
更多
知识
篇文章
面的
帮助
这不
信息
多个
学生
常用
序号
想法
数据
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
治安管理处罚法 网络安全
数据库技术及其发展方向浅谈
参观网络技术公司心得通用
高中生从事软件开发有影响吗
数据库.bak文件打开
数据库查询显示成绩后3名的学生
在云服务器上启动服务
变电站网络安全态势感知系统
国防科技大学网络安全专业不好吗
美国网络安全产业商业模式
上海子母钟服务器
新乡翰海网络技术有限公司
确定网络安全
服务器与时间服务器同步
win10服务器c盘需要多大
跟网络安全有关的画
浏览器提示服务器正在运行中
长宁区新时代软件开发加工厂
苍南刀片服务器不二之选
饥荒专用服务器列表是空的
虹口区正规软件开发市场价
有人N540串口服务器
一点一滴互联网科技
体验服为啥显示服务器未响应
安苏服务器大战
浙江网络技术咨询询问报价
数据库查询面试
服务器集群的网络
自己接软件开发私活
nosql数据库教材