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

 更新时间:2022年10月25日 11:00:36   作者:小白鸭  
经常在分组查询之后,需要的是分组的某行数据,例如更新时间最新的一条数据,下面这篇文章主要给大家介绍了关于SQL Group By分组后如何选取每组最新的一条数据的相关资料,需要的朋友可以参考下

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

问题

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

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

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

SELECT * FROM `temp`  GROUP BY address

结果如下:

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

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

看看结果:

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

方法一:加limit关键字

SELECT
	* 
FROM
	(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树形结构的数据库表设计方案

    树形结构对大家来说应该都不陌生,在日常开发中经常会遇到,下面这篇文章主要给大家介绍了关于Mysql树形结构的数据库表设计的相关资料,文中通过示例代码的非常详细,需要的朋友可以参考下
    2021-09-09
  • MySQL隐式类型转换导致索引失效的解决

    MySQL隐式类型转换导致索引失效的解决

    本文主要介绍了MySQL隐式类型转换导致索引失效的解决,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • windows下MySQL5.6版本安装及配置过程附有截图和详细说明

    windows下MySQL5.6版本安装及配置过程附有截图和详细说明

    这篇文章主要介绍了windows下MySQL5.6版本安装及配置过程附有截图和详细说明,需要的朋友可以参考下
    2013-06-06
  • MySQL之导出整个及单个表数据的操作

    MySQL之导出整个及单个表数据的操作

    这篇文章主要介绍了MySQL之导出整个及单个表数据的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • Mysql CPU占用高的问题解决方法小结

    Mysql CPU占用高的问题解决方法小结

    最近发现php网站发布信息比较慢,而且同网站目录下的asp经常登录后立即就重新登录,立即考虑到服务器资源占用问题,所以进服务器看到原来mysql占用率较高 25-60%左右,偶尔能跑到100%,所有导致上述问题的发生
    2012-06-06
  • Mysql的timeout以及python重连方式

    Mysql的timeout以及python重连方式

    这篇文章主要介绍了Mysql的timeout以及python重连方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • 在MySQL 8.0版本中开启远程登录详细的操作步骤

    在MySQL 8.0版本中开启远程登录详细的操作步骤

    有时数据库所在机器与项目运行的机器不是同一个,那么就涉及到远程链接数据库了,下面这篇文章主要给大家介绍了关于在MySQL 8.0版本中开启远程登录详细的操作步骤,需要的朋友可以参考下
    2024-04-04
  • mysql 实现添加时间自动添加更新时间自动更新操作

    mysql 实现添加时间自动添加更新时间自动更新操作

    这篇文章主要介绍了mysql 实现添加时间自动添加更新时间自动更新操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • 最新版MySQL 8.0.22下载安装超详细教程(Windows 64位)

    最新版MySQL 8.0.22下载安装超详细教程(Windows 64位)

    这篇文章主要介绍了最新版MySQL 8.0.22下载安装超详细教程(Windows 64位),本文通过图文实例相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • 为什么在MySQL中不建议使用UTF-8

    为什么在MySQL中不建议使用UTF-8

    在本篇文章里小编给大家分享了一篇关于MySQL中不要使用UTF-8的相关文章,有兴趣的朋友们可以阅读参考下。
    2020-12-12

最新评论