添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

SQL Group By分组后如何选取每组最新的一条数据

作者:小白鸭

经常在分组查询之后,需要的是分组的某行数据,例如更新时间最新的一条数据,下面这篇文章主要给大家介绍了关于SQL Group By分组后如何选取每组最新的一条数据的相关资料,需要的朋友可以参考下

Group By分组后选取每组最新的一条数据

group by语句只会展示一条数据,而且很多时候并不会展示我们想要的数据,如何解决呢

首先我们先建一张表 temp,如下

我们先试一下分组查询,看看结果

SELECT * FROM `temp`  GROUP BY address

结果如下:

它默认是取的id最小的那一条数据,如果想要取最新的一条呢,我们试试先排序再分组

SELECT
	(SELECT * FROM `temp` ORDER BY `create_time` desc) AS t 
GROUP BY
	t.`address`

看看结果:

发现结果没变,就像排序好像没生效一样,下面有两种解决方法

方法一:加limit关键字

SELECT
	(SELECT * FROM `temp` ORDER BY `create_time` desc limit 100) AS t 
GROUP BY
	t.`address`

现在结果就是我们想要的了

但是limit关键字,有时候可能不好限制范围,如果你想查所有的数据呢,难道要单独查一下有多少条数据,再limit吗,好像显得不太专业,所以下面有方法二

方法二:用max函数

SELECT t1.* 
FROM `temp` t1,
( SELECT MAX( id ) id FROM `temp` GROUP BY address ) AS t2 
WHERE
	t1.id = t2.id

这种事先将每个分组最大的id取出来,再拼接数据,也能达到一样的效果,结果如下:

如果你不想取最新的,想取中间某个范围的,还能加where条件

SELECT t1.* 
FROM `temp` t1,
( SELECT MAX( id ) id FROM `temp` WHERE create_time < '2022-08-16' GROUP BY address ) AS t2 
WHERE
	t1.id = t2.id

结果如下:

好啦,问题解决了

到此这篇关于SQL Group By分组后如何选取每组最新的一条数据的文章就介绍到这了,更多相关Group By分组选取最新数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • MySQL触发器使用过程详解
    MySQL触发器使用过程详解
    2023-03-03
  • mysql一次将多条不同sql查询结果并封装到一个结果集的实现方法
    mysql一次将多条不同sql查询结果并封装到一个结果集的实现方法
    2023-03-03
  • mariadb集群搭建---Galera Cluster+ProxySQL教程
    mariadb集群搭建---Galera Cluster+ProxySQL教程
    2023-03-03
  • 数据库报错:Unknown column 'xxx' in 'where clause'问题的解决过程
    数据库报错:Unknown column 'xxx' in 
    2023-03-03
  • MySQL如何查询Binlog 生成时间
    MySQL如何查询Binlog 生成时间
    2023-03-03
  • order by + limit分页时数据重复问题及解决方法
    order by + limit分页时数据重复问题及解决方法
    2023-03-03
  • 利用Mysql定时+存储过程创建临时表统计数据的过程
    利用Mysql定时+存储过程创建临时表统计数据的过程
    2023-03-03
  • 一步步教你利用Mysql存储过程造百万级数据
    一步步教你利用Mysql存储过程造百万级数据
    2023-03-03
  • 美国设下计谋,用娘炮文化重塑日本,已影响至中国
    美国设下计谋,用娘炮文化重塑日本,已影响至中国
    2021-11-19
  • 时空伴随者是什么意思?时空伴随者介绍
    时空伴随者是什么意思?时空伴随者介绍
    2021-11-09
  • 工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    2021-11-05
  • 2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2021-10-26
  • 电脑版 - 返回首页

    2006-2023 脚本之家 JB51.Net , All Rights Reserved.
    苏ICP备14036222号