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安全错误
数据库的锁怎样保障安全
电脑文件管理软件开发源代码
据相关媒体报道网络安全事故
软件开发工作量认定纠纷案
java nio服务器
游戏出租网络安全
外文网络技术相关文献
路由器http服务器什么意思
如何关掉网络安全防护
access数据库mfc
上海常用软件开发服务至上
汽车合格证信息多久传到数据库
c 程序设计与软件开发
广电网络安全生产培训简报
金蝶 数据库结构
斗罗大陆服务器的地址
青岛世纪商泰网络技术
服务器安全狗没更新了
如何查看数据库的源码
北京经济网络技术学院
数据库应用技术选择题题库
政企网络安全服务
坦克世界不同服务器互通吗
网络安全设备政策
网络安全法对个人的要求
x58服务器主板开机跳线
国内知名服务器
网络安全周活动信息
zk服务器
网络安全为人民前抄报
魔兽的世界80级数据库