Mysql数据分组排名实现的示例分析
发表于:2025-01-17 作者:千家信息网编辑
千家信息网最后更新 2025年01月17日,Mysql数据分组排名实现的示例分析,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1.数据源2.数据整体排名1)普通排名
千家信息网最后更新 2025年01月17日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安全错误
数据库的锁怎样保障安全
安徽服务器报废哪家正规
网络安全基础知识点总结
清空orcle数据库
服务器设置u盘优先启动
.net 多个数据库
广东销售软件开发商
株洲软件开发师培训排名
利用企业管理器删除数据库
颍上县网络安全宣传片
怎样学做软件开发
华为高斯数据库金融案例
关于转发网络安全防范通知
服务器如何测试带宽
抽奖活动数据库设计
软件开发设计怎么样
中国网络安全大计事
新加坡网络技术交流会
工业通信网络安全
iis元数据库
十二部委联合发文网络安全
安徽服务器报废哪家正规
设计数据库表结构用什么工具
全球网络安全大学排名与分数
网络安全提上日程
cas管理多个服务器
软件开发加计扣除的要求
软件开发刚毕业上哪找工作
2万人流量要用多大的服务器
成都星宇软件开发有限公司
在数据库中参照完整性规则包括