Mysql数据分组排名实现的示例分析
发表于:2024-10-01 作者:千家信息网编辑
千家信息网最后更新 2024年10月01日,Mysql数据分组排名实现的示例分析,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1.数据源2.数据整体排名1)普通排名
千家信息网最后更新 2024年10月01日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安全错误
数据库的锁怎样保障安全
南邮网络安全技术
通信网络技术特点
中铁的软件开发技术岗怎么样
打印机rpc服务器出现错误
联想一体机dns服务器没有响应
做服务器出租怎么那么赚钱
五常软件开发者在线咨询
围绕网络安全防范的重要意义
hive 刷新数据库
火鸟数据库 连接 sql
数据库是否型
网络安全警示教育片下载
怎么进入学校的数据库看试卷
给服务器装系统和驱动
青岛计算机软件开发招聘信息
教师数据库 内容
电脑硬件数据库文件
服务器ssh前的基础配置
数据库启动发生系统错误5
如何快速把数据导入数据库
上万台服务器如何管理
java软件开发指的
下列语句中可以创建数据库的是
服务器管理 php网站
定制app软件开发平台宁波
数据库添加修改数据表
督察网络安全应急预案
造梦西游ol以前的服务器去哪了
暨育互联网科技有限公司
scum自建服务器有vac吗