Mysql数据分组排名实现的示例分析
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,Mysql数据分组排名实现的示例分析,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1.数据源2.数据整体排名1)普通排名
千家信息网最后更新 2025年11月07日Mysql数据分组排名实现的示例分析
Mysql数据分组排名实现的示例分析,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
1.数据源
2.数据整体排名
1)普通排名
从1开始,按照顺序一次往下排(相同的值也是不同的排名)。
set @rank =0;select city , score, @rank := @rank+1 rank from cs order by score desc;
结果如下:
2)并列排名
相同的值是相同的排名(但是不留空位)。
set @rank=0,@price=null;select cs.* , case when @price = score then @rank when @price := score then @rank := @rank+1 end rank from cs order by score desc; -- 当查询的score 值 = @price时,输出@rank, -- 当不等时,将score值赋给@price ,并输出@rank := @rank+1 -- 或者set @rank=0,@price=null;select a.city,a.score,a.rank from (select cs.*, @rank := if(@p=score,@rank,@rank+1) rank, @p := scorefrom cs order by score desc) a;
结果如下:
3)并列排名
相同的值是相同的排名(但是留空位)。
set @rank=0,@price=null, @z=1;select a.city,a.score,a.rank from (select cs.*, @rank := if(@p=score,@rank,@z) rank, @p := score,@z :=@z+1from cs order by score desc) a;
结果如下:
3.数据分组后组内排名
1)分组普通排名
从1开始,按照顺序一次往下排(相同的值也是不同的排名)。
set @rank=0,@c=null;select cs.city,cs.score, @rank := if(@c = city,@rank+1,1) rank, @c := cityfrom cs order by cs.city,cs.score;
结果如下:
2)分组后并列排名
组内相同数值排名相同,不占空位。
set @rank=0,@c=null,@s=null;select cs.city,cs.score, @rank := if(@c=city,if(@s=score,@rank,@rank+1),1) rank , @c := city, @s :=score from cs order by cs.city,cs.score;
结果如下:
3)分组后并列排名
组内相同数值排名相同,需要占空位。
set @rank=0,@c=null,@s=null;select cs.city,cs.score, @rank := if(@c=city,if(@s=score,@rank,@rank+1),1) rank , @c := city, @s :=score from cs order by cs.city,cs.score;
结果如下:
4.分组后取各组的前两名
① 方法一:按照分组排名的三种方式,然后限定排名的值
set @rank=0,@z=0,@c=null,@s=null;select a.city,a.score,a.rank from (select cs.city city,cs.score score, @z := if(@c=city,@z+1,1), @rank := if(@c=city,if(@s=score,@rank,@z),1) rank, @c := city, @s :=score from cs order by cs.city,cs.score desc) awhere a.rank<=2;
结果如下:
② 内部查询
SELECT * FROM cs cWHERE ( SELECT count(*) FROM cs WHERE c.city=cs.city AND c.score结果如下:
上述代码的执行原理如下图:
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对的支持。
相同
结果
分组
数据
空位
不同
普通
数值
顺序
帮助
查询
输出
示例
分析
清楚
代码
内容
原理
对此
数据源
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
数据库需要激活码
网络安全宣传问卷
数据库文件干什么用的
数据库表示所有列
如何把数据库中的表相互连接起来
网络安全法治宣传教育小结
软件开发要懂硬件吗
云端下载软件开发
周鸿祎国家网络安全宣传周
计算机网络技术好写论文
万方数据库怎么下载中外标准
饥荒服务器mod管理
苹果8认证数据库
if() 数据库
网络安全法规定的原则有
小程序云数据库读取图片
郴州人事软件开发招聘
三级数据库技术选择填空
杭州品牌网络技术包括什么
多人开发软件开发
福州爱特网络技术有限公司
胡桃复刻挤爆服务器
网络安全小心行观后感
网络技术基本应用的总结
景晨网络技术有限公司
柳州移动首选dns服务器
网络安全事件 中国移动
电商互联网和科技发展
肇庆软件开发公司app开发
人工智能企业数据库系统的目的
