mysql分组后排序取第一条,mysql分组排序取第一条记录

2023-10-08 02:10

本文主要是介绍mysql分组后排序取第一条,mysql分组排序取第一条记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先说结论:在Mysql中,通过GroupBy分组后,会取主键ID最小的一条数据作为分组后的数据。如果存在需求,根据其他字段排序后取对应字段最大或者最小值的话,通过SQL语句是可以实现的,核心在于排序后需要加Limit xx。

先直接看结论

数据如下:

id

user_name

user_sex

user_age

1

张三18

18

2

李四17

17

3

王丽18

18

4

孔梦19

19

需求:查询出男生女生年龄最小的数据

正确解法select id,user_name,user_sex,user_age from (

SELECT id,user_name,user_sex,user_age FROM `user_test`

order by user_age

limit 100

)A

group by A.user_sex

结果如下:

id

user_name

user_sex

user_age

2

李四17

17

3

王丽18

18

常规思路(不知道加 limit)select id,user_name,user_sex,user_age from (

SELECT id,user_name,user_sex,user_age FROM `user_test`

order by user_age

)A

group by A.user_sex

结果如下:

id

user_name

user_sex

user_age

1

张三18

18

3

王丽18

18

男生是取的年龄最大的,女生则是年龄最小的,唯一的共同点在于取得值都是各自分组内 ID 最小的那个

验证

为了验证 GroupBy 以后是以id取优先级,我改一下id值,可以发现分组后永远取的是 id 最小的那个,跟group by的字段没任何关系

9c27dee11fdbb71fb4f7a6428d9b8dca.png

1770b16ccd40baa9b720c28f27669cee.png

a28eb63d9ac1a64563bdee2e9a9a6692.png

![]

0418d6d8eaa3494ac3546865dfd6d1bd.png

原因

在知乎上找到了相应的问题,发现有人说是命中主键 id 最小的,也有人说是谬 论。根据提供的资料,还是看不懂。目前只能先记录下当前的解决方案。

GROUP BY是如何选择哪一条数据留下的?,

优化

limit xx ,可以默认写成 1000 这种,但是如果实际场景每组的数据量很大的话,limit 太小了可能直接就导致数据不全了,可以采用动态拼接 SQL 语句的办法:先查询出指定条件数据的个数(dataCount),将 datacount 作为参数替换 xx 即可。

这篇关于mysql分组后排序取第一条,mysql分组排序取第一条记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/161995

相关文章

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Mysql实现范围分区表(新增、删除、重组、查看)

《Mysql实现范围分区表(新增、删除、重组、查看)》MySQL分区表的四种类型(范围、哈希、列表、键值),主要介绍了范围分区的创建、查询、添加、删除及重组织操作,具有一定的参考价值,感兴趣的可以了解... 目录一、mysql分区表分类二、范围分区(Range Partitioning1、新建分区表:2、分

MySQL 定时新增分区的实现示例

《MySQL定时新增分区的实现示例》本文主要介绍了通过存储过程和定时任务实现MySQL分区的自动创建,解决大数据量下手动维护的繁琐问题,具有一定的参考价值,感兴趣的可以了解一下... mysql创建好分区之后,有时候会需要自动创建分区。比如,一些表数据量非常大,有些数据是热点数据,按照日期分区MululbU

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

MySQL中查找重复值的实现

《MySQL中查找重复值的实现》查找重复值是一项常见需求,比如在数据清理、数据分析、数据质量检查等场景下,我们常常需要找出表中某列或多列的重复值,具有一定的参考价值,感兴趣的可以了解一下... 目录技术背景实现步骤方法一:使用GROUP BY和HAVING子句方法二:仅返回重复值方法三:返回完整记录方法四:

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

MySQL中的锁机制详解之全局锁,表级锁,行级锁

《MySQL中的锁机制详解之全局锁,表级锁,行级锁》MySQL锁机制通过全局、表级、行级锁控制并发,保障数据一致性与隔离性,全局锁适用于全库备份,表级锁适合读多写少场景,行级锁(InnoDB)实现高并... 目录一、锁机制基础:从并发问题到锁分类1.1 并发访问的三大问题1.2 锁的核心作用1.3 锁粒度分