mysql实现分组排序和不分组排序

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: mysql实现分组排序和不分组排序

大前提

假如你不懂mysql中“=”和“:=”的区别,需要去补习一下这两个知识的用法。

关于mysql中“=”和“:=”的区别,可以参考我的另外一篇文章。https://blog.csdn.net/weixin_41261833/article/details/103509526

本文如果有不懂的地方,可以留言。

一、不分组排序

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

-- 方法一
select m.*,@r :=@r + 1 as rank
from mian62 m,(select @r := 0) r
order by score desc;
-- 方法二
set @r=0;
select m.*,@r :=@r + 1 as rank
from mian62 m
order by score desc;


效果如下:

image.png


2、并列排名:相同的值是相同的排名(但是不留空位)。

-- 方法一
select c.sid,c.name,c.score,c.rank
from
(
  select m.*,
  @c:=if(@p=score,@c,@r) as rank,
  @p:=score,
  @r:=@r+1
  from mian62 m,(select @p:=0,@r:=1,@c:=0)r
  order by score desc
)c
-- 方法二
set @p=0;
set @r=1;
set @c=0;
select c.sid,c.name,c.score,c.rank
from
(
  select m.*,
  @c:=if(@p=score,@c,@r) as rank,
  @p:=score,
  @r:=@r+1
  from mian62 m
  order by score desc
)c


效果如下:

image.png


2、并列排名:相同的值是相同的排名(但是留空位)。

-- 方法一
select c.sid,c.name,c.score,c.rank
from
(
  select m.*,
  @c:=if(@p=score,@c,@r) as rank,
  @p:=score,
  @r:=@r+1
  from mian62 m,(select @p:=0,@r:=1,@c:=0)r
  order by score desc
)c
-- 方法二
set @p=0;
set @r=1;
set @c=0;
select c.sid,c.name,c.score,c.rank
from
(
  select m.*,
  @c:=if(@p=score,@c,@r) as rank,
  @p:=score,
  @r:=@r+1
  from mian62 m
  order by score desc
)c


效果如下:

image.png


二、分组后排序

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

select a.sid,a.name,a.subject,a.score,a.rank
from  
(
  select m.*,
  if(@p=subject,@r:=@r+1,@r:=1) as rank,
  @p:=subject
  from mian62 m,(select @p:=0,@r:=0)r
  order by subject,score desc
)a;


效果如下:

image.png

2、分组后并列排名:组内相同数值排名相同。

-- 为了体现效果,修改其中一条数据;
update mian62 set score=58 where name="张三" and subject="化学";
-- 本题实现代码如下:
select a.sid,a.name,a.subject,a.score,a.rank
from 
(
  select *,
  if(@p=subject,
  case 
  when @s=score then @r
  when @s:=score then @r:=@r+1
  end,
  @r:=1 ) as rank,
  @p:=subject,
  @s:=score
  from mian62 m,(select @p:=0,@s:=0,@r:=0)r
  order by subject,score
)a;


效果如下:

image.png

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4月前
|
自然语言处理 关系型数据库 MySQL
如何在mysql数据库里进行文本的相似度排序?
【8月更文挑战第28天】如何在mysql数据库里进行文本的相似度排序?
391 62
|
1月前
|
SQL NoSQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(5)作者——LJS[含MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页等详解步骤及常见报错问题所对应的解决方法]
MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页、INSERT INTO SELECT / FROM查询结合精例等详解步骤及常见报错问题所对应的解决方法
|
2月前
|
SQL 搜索推荐 关系型数据库
MySQL 如何实现 ORDER BY 排序?
本文详细解析了MySQL中`ORDER BY`的实现原理及优化方法。通过解析与优化、执行及多种优化技术,如索引利用、内存排序、外部排序等,帮助你提升排序性能。了解其背后的机制,可显著优化查询效率。
86 4
|
2月前
|
SQL 搜索推荐 关系型数据库
MySQL 如何实现 ORDER BY 排序?
在实际开发中,我们经常会使用 MySQL 的 `ORDER BY`进行排序,那么,`ORDER BY`是如何实现的排序的?我们该如何优化 `ORDER BY`的排序性能?这篇文章,我们来聊一聊。
39 3
|
3月前
|
算法 关系型数据库 MySQL
MySQL高级篇——排序、分组、分页优化
排序优化建议、案例验证、范围查询时索引字段选择、filesort调优、双路排序和单路排序、分组优化、带排序的深分页优化
MySQL高级篇——排序、分组、分页优化
|
3月前
|
自然语言处理 关系型数据库 MySQL
match如何在mysql数据库里进行文本的相似度排序?
【9月更文挑战第1天】match如何在mysql数据库里进行文本的相似度排序?
125 1
|
9天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
73 15
|
3天前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。
|
10天前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
14天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。