返回顶部
首页 > 资讯 > 数据库 >MySql Group by函数怎么正确使用
  • 638
分享到

MySql Group by函数怎么正确使用

2024-04-02 19:04:59 638人浏览 泡泡鱼
摘要

这篇文章主要介绍了Mysql Group by函数怎么正确使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mysql Group by函数怎么正确使用文章都会有所收获,下面我

这篇文章主要介绍了Mysql Group by函数怎么正确使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mysql Group by函数怎么正确使用文章都会有所收获,下面我们一起来看看吧。

在使用分组函数时, 进行结果集筛选, 遇到的一些问题以及解决办法

1. 应用场景

有两张表

文章表(一对多留言表) t_posts:      
oid, posts_name    
留言表(多对一文章表) t_comment:    
oid, posts_id, msg_content, create_time

2.需求分析

查询每个文章的最新回复内容

3.SQL编写

select 
  tp.oid,
  tp.posts_name,
  tc.msg_content,
  tc.create_time
from t_posts tp 
left join t_comment tc on tp.oid = tc.posts_id
group by tp.oid having create_time = max(create_time)

假设现在有两个文章A, B (回复的记录在数据库的顺序与下述一致)

A有一个回复记录时间为: 2019-09-10  
A有一个回复记录时间为: 2019-09-11  
B有一个回复记录时间为: 2019-09-01  
B有一个回复记录时间为: 2019-09-09

运行上面的sql, 会发现结果集丢失大量记录, 并且结果是错误的, 经过查询资料得知

mysql的 having 是在 group by 之后再执行, 也就是说, 先分组, 在过滤, 但是因为存在两条以上的留言记录,
所以分组之后的结果集只会取每条留言的第一条作为分组之后的记录信息, 这时如果使用having create_time = max(create_time)
那么, max(create_time) 为当前分组的最大时间

为: 2019-09-10 和 2019-09-09

所以上述sql会丢失结果集

4.改造SQL

因为知道分组之后合并的重复结果集为rownum最小的那条, 那么可不可以改造sql如下??

select 
  tp.oid,
  tp.posts_name,
  tc.msg_content,
  tc.create_time
from t_posts tp 
left join t_comment tc on tp.oid = tc.posts_id
group by tp.oid having create_time = max(create_time)
-- 下面的是新增的sql
order by tc.create_time desc

运行之后发现依旧不好使, 证明order by 在group by & having 之后

后来想想可不可以 不用having, 直接用order by来优化分组后的结果呢?

having create_time = max(create_time)

select 
  tp.oid,
  tp.posts_name,
  tc.msg_content,
  tc.create_time
from t_posts tp 
left join t_comment tc on tp.oid = tc.posts_id
group by tp.oid 
order by tc.create_time desc

结果集错误, 并不能影响分组结果, 依旧是按照rownum最小分组合并重复结果集, 然后在排序

5.终极改造版本

因为order by 只能后影响group by, 那么是不是可以在group by 之前先把结果集排序一下, 然后再分组呢?

select * from (
  select 
    tp.oid,
    tp.posts_name,
    tc.msg_content,
    tc.create_time
  from t_posts tp 
  left join t_comment tc on tp.oid = tc.posts_id
  order by tc.create_time desc
) t 
group by t.oid

发现还是不好使, 但是子查询确实先排序了

经查询(explain), 发现子查询的order by被优化没了, 解决办法:

  1. 在子查询里使用limit 99999

  2. 在子查询里使用where条件, create_time = (select max(create_time) from t_comment group by oid)

select * from (
  select 
    tp.oid,
    tp.posts_name,
    tc.msg_content,
    tc.create_time
  from t_posts tp 
  left join t_comment tc on tp.oid = tc.posts_id
  order by tc.create_time desc limit 9999
) t 
group by t.oid

大功告成

附加知识点:

mysql5.5 与 mysql 5.7 版本差异: 5.7+ 版本, 如果不使用 limit, group by 会把 order by 优化掉

关于“MySql Group by函数怎么正确使用”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“MySql Group by函数怎么正确使用”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: MySql Group by函数怎么正确使用

本文链接: https://www.lsjlt.com/news/72034.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySql Group by函数怎么正确使用
    这篇文章主要介绍了MySql Group by函数怎么正确使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇MySql Group by函数怎么正确使用文章都会有所收获,下面我...
    99+
    2024-04-02
  • MySQL的order by怎么正确使用
    这篇文章主要介绍“MySQL的order by怎么正确使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL的order by怎么正确使用”文章能帮助大家解决...
    99+
    2024-04-02
  • MySQL时间函数怎么正确使用
    MySQL中有很多时间函数,可以对日期和时间进行各种操作和计算。下面是一些常用的MySQL时间函数及其正确使用方法:1. NOW()...
    99+
    2023-08-15
    MySQL
  • mysql中count(), group by, order by怎么用
    这篇文章给大家分享的是有关mysql中count(), group by, order by怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。mysql中count(), gr...
    99+
    2024-04-02
  • mysql GROUP BY 怎么 order by 排序
    在 MySQL 中使用 GROUP BY 子句时,如果需要对结果进行排序,可以使用 ORDER BY 子句来对分组后的结果进行排序。 ORDER BY 子句应该放在 GROUP BY 子句之后,使用逗号来分隔需要排序的列,并在排序列后指定排...
    99+
    2023-09-09
    mysql 数据库 排序算法
  • access中group by怎么使用
    在Access中,GROUP BY子句用于对查询结果进行分组。它通常与聚合函数(如SUM、COUNT、AVG)一起使用,以便对每个组...
    99+
    2023-10-11
    access
  • 怎么正确使用函数指针数组
    这篇文章将为大家详细讲解有关怎么正确使用函数指针数组,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。上回开发某软件过程中遇到这样一个问题,前级模块传给我二进制数据,输入参数为 char* buffer和 i...
    99+
    2023-06-17
  • mysql中group by如何使用
    小编给大家分享一下mysql中group by如何使用,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!mysql中group by的用法是配合聚合函数,利用分组信息进行统计,语句如“selec&...
    99+
    2024-04-02
  • 数据库中的group by怎么使用
    在数据库中,GROUP BY子句用于根据一个或多个列对结果进行分组。它常用于与聚合函数一起使用,以便对每个组应用聚合函数。语法如下:...
    99+
    2023-08-30
    数据库
  • mysql常用函数之group_concat()、group by、count()、case when then的使用
    目录场景:一、行转列函数 group_concat(arg)二、分组 group by、count()、sum() 函数的组合使用三、count() 配合 case when then&nb...
    99+
    2023-01-04
    mysql group_concat() groupby count() casewhenthen
  • MySQL group by和order by如何一起使用
    假设有一个表:reward(奖励表),表结构如下: CREATE TABLE test.reward ( id int(11) NOT NULL AUTO_INCREMENT, uid int(11) NOT...
    99+
    2022-05-27
    MySQL group by order by
  • 怎么正确使用mysql dump
    本篇内容主要讲解“怎么正确使用mysql dump”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么正确使用mysql dump”吧!1、如果mysql dum...
    99+
    2024-04-02
  • sql语句group by怎么使用
    在SQL语句中,使用GROUP BY子句可以按照一个或多个列对结果进行分组。它通常与聚合函数(如SUM、COUNT、AVG等)一起使...
    99+
    2023-10-10
    sql
  • 云数据库MySQL怎么正确使用
    使用云数据库MySQL的步骤如下: 创建MySQL实例:登录云数据库控制台,在实例列表页点击“创建实例”,选择MySQL数据库引...
    99+
    2024-04-09
    云数据库MySQL MySQL
  • 数据库中group by怎么用
    这篇文章将为大家详细讲解有关数据库中group by怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一.  概述group_by的意思是根据by对数据按照哪个字段进行分组,或者是哪...
    99+
    2023-06-22
  • 将 MySQL SUM() 函数与 GROUP BY 子句一起使用有什么好处?
    当我们将 MySQL SUM() 函数与 GROUP BY 子句一起使用时,SUM() 函数会计算 GROUP BY 子句中指定的每个组的总和。将 SUM() 与 GROUP BY 子句一起使用的好处是我们可以轻松找到特定组的总计。要理解上...
    99+
    2023-10-22
  • MySQL基础教程13 —— 函数之与GROUP BY子句同时使用的函数
    1. GROUP BY(聚合)函数 本章论述了用于一组数值操作的 group (集合)函数。除非另作说明, group 函数会忽略 NULL 值。 假如你在一个不包含 ROUP BY子句的语句中使用一个 group函...
    99+
    2022-05-17
    GROUP BY MySQL 函数 聚合函数
  • sql中group by和oder by怎么一起使用
    使用 group by 和 order by 可以对分组数据进行排序:1. group by 分组数据;2. order by 对每组数据排序。 SQL 中 GROUP BY 和 OR...
    99+
    2024-05-02
    聚合函数
  • mysql查询语句group by和order by的使用
    这篇文章主要讲解了“mysql查询语句group by和order by的使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql查询语句group b...
    99+
    2024-04-02
  • mysql中的group by 和 having使用
    mysql中的group by 和 having 使用 理论 –sql中的group by 用法解析: – Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(G...
    99+
    2023-09-14
    mysql 数据库 sql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作