Mysql教程分组排名实现示例详解

作者:数据分析与统计学之美 时间:2024-01-18 14:19:49 

1.数据源

Mysql教程分组排名实现示例详解

2.数据整体排名

1)普通排名

从1开始,按照顺序一次往下排(相同的值也是不同的排名)。


set @rank =0;
select
city ,
score,
@rank := @rank+1 rank
from cs
order by score desc;

结果如下:

Mysql教程分组排名实现示例详解

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 := score
from cs
order by score desc) a;

结果如下:

Mysql教程分组排名实现示例详解

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+1
from cs
order by score desc) a;

结果如下:

Mysql教程分组排名实现示例详解

3.数据分组后组内排名

1)分组普通排名

从1开始,按照顺序一次往下排(相同的值也是不同的排名)。


set @rank=0,@c=null;
select
cs.city,cs.score,
@rank := if(@c = city,@rank+1,1) rank,
@c := city
from cs
order by cs.city,cs.score;

结果如下:

Mysql教程分组排名实现示例详解

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;

结果如下:

Mysql教程分组排名实现示例详解

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;

结果如下:

Mysql教程分组排名实现示例详解

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) a
where a.rank<=2;

结果如下:

Mysql教程分组排名实现示例详解

② 内部查询


SELECT * FROM cs c
WHERE (
   SELECT count(*) FROM cs
   WHERE c.city=cs.city AND c.score<cs.score )<2
ORDER BY city,score DESC;

结果如下:

Mysql教程分组排名实现示例详解

上述代码的执行原理如下图:

Mysql教程分组排名实现示例详解

来源:https://huang-tong-xue.blog.csdn.net/article/details/106728135

标签:Mysql,分组排名
0
投稿

猜你喜欢

  • SQL Server 数据库备份和还原认识和总结 (一)

    2012-10-07 10:52:54
  • Python常用内置函数的使用教程详解

    2021-11-11 21:23:50
  • 自动在Windows中运行Python脚本并定时触发功能实现

    2023-04-15 21:12:38
  • 简单说明Python中的装饰器的用法

    2022-01-30 21:57:32
  • python区块链持久化和命令行接口实现简版

    2023-10-28 09:43:08
  • mysql 定时任务的实现与使用方法示例

    2024-01-17 17:07:48
  • 什么样的图标更具有可用性

    2007-10-16 17:47:00
  • Python Tkinter Menu组件详解

    2021-07-24 06:51:18
  • Python利用逻辑回归分类实现模板

    2023-11-14 07:02:05
  • python通过opencv实现批量剪切图片

    2021-05-12 12:50:14
  • 利用python实现简单的邮件发送客户端示例

    2022-06-19 18:25:07
  • python 窃取摄像头照片的实现示例

    2021-12-27 19:16:11
  • lodash内部方法getData和setData实例解析

    2024-04-19 09:43:12
  • RHEL下架设MYSQL集群

    2008-12-24 16:05:00
  • 深入string理解Golang是怎样实现的

    2024-02-07 06:45:24
  • 监测站点使用多少session和application的asp程序

    2007-09-12 19:40:00
  • nacos只支持mysql的原因分析

    2024-01-17 21:11:23
  • python文件写入write()的操作

    2023-11-10 04:33:11
  • mysql语法之DQL操作详解

    2024-01-19 09:39:10
  • Python 实现删除某路径下文件及文件夹的实例讲解

    2021-05-07 08:31:49
  • asp之家 网络编程 m.aspxhome.com