mysql分组后如何每个取最新的一条记录

 更新时间:2024年09月20日 09:48:06   作者:huanhuan_m1  
在MySQL中获取每个分组的最新记录可以通过子查询或窗口函数实现,使用子查询时,通过设定时间戳字段确定最新记录,并利用LIMIT子句获取,若MySQL版本支持窗口函数(如MySQL 8.0+),可使用ROW_NUMBER()配合PARTITION BY和ORDER BY实现同样效果

mysql分组后每个取最新的一条记录

在MySQL中,若要从一个分组中获取每组的最新一条记录(通常基于时间戳或其他递增的列),可以使用子查询或者窗口函数(如果MySQL版本支持)。

以下是两种不同的实现方法:

方法1

使用子查询和LIMIT子句

SELECT t1.*
FROM your_table t1
INNER JOIN (
    SELECT id, MAX(timestamp) AS max_timestamp
    FROM your_table
    GROUP BY id
) t2 ON t1.id = t2.id AND t1.timestamp = t2.max_timestamp;

在这个查询中:

  • your_table 是你要查询的表名。
  • id 是用于分组的字段。
  • timestamp 是用于确定哪条记录是“最新”的时间戳字段。

方法2

使用窗口函数ROW_NUMBER()(如果MySQL 8.0+)

SELECT id, other_columns, timestamp
FROM (
    SELECT id, other_columns, timestamp,
           ROW_NUMBER() OVER(PARTITION BY id ORDER BY timestamp DESC) as rn
    FROM your_table
) t
WHERE rn = 1;

在这个查询中:

  • other_columns 代表你需要选择的其他列。
  • ROW_NUMBER() 函数会为每个分组内的行分配一个唯一的数字,按timestamp降序排列,最新的记录会得到rn = 1。
  • PARTITION BY id 指定了分组依据。
  • ORDER BY timestamp DESC 确保了在每个分组内部按照时间戳降序排序。

这两种方法都可以确保每个分组中只选择最新的一条记录。

  • 在方法1中,先通过子查询找到每个分组中的最新日期,然后通过连接操作获取对应的记录。
  • 在方法2中,使用窗口函数ROW_NUMBER()对每个分组内的记录进行排序,并给每条记录分配一个行号,然后筛选出行号为1的记录。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • mysql压缩包版zip安装配置方法

    mysql压缩包版zip安装配置方法

    这篇文章主要为大家详细介绍了mysql压缩包版zip安装配置方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-02-02
  • MYSQL数据库GTID实现主从复制实现(超级方便)

    MYSQL数据库GTID实现主从复制实现(超级方便)

    这篇文章主要介绍了MYSQL数据库GTID实现主从复制实现(超级方便),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • MySQL之FIELD()与ORDER BY()相结合实现对结果的自定义排序方式

    MySQL之FIELD()与ORDER BY()相结合实现对结果的自定义排序方式

    这篇文章主要介绍了MySQL之FIELD()与ORDER BY()相结合实现对结果的自定义排序方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • 详解MySQL数据库的安装与密码配置

    详解MySQL数据库的安装与密码配置

    本文主要对MySQL数据库的安装与密码配置进行详细介绍,具有一定的参考价值。下面就跟小编一起来看下吧
    2016-12-12
  • MySQL表数据文件损坏导致数据库无法启动的原因与解决方案

    MySQL表数据文件损坏导致数据库无法启动的原因与解决方案

    在日常的数据库管理中,遇到MySQL表数据文件损坏的情况并不罕见,这种情况下,MySQL数据库可能会无法正常启动,给业务运行带来严重影响,本文将探讨如何诊断和解决MySQL表数据文件损坏导致的数据库无法启动问题,需要的朋友可以参考下
    2025-03-03
  • Docker mysql 主从配置详解及实例

    Docker mysql 主从配置详解及实例

    这篇文章主要介绍了Docker mysql 主从配置详解及实例的相关资料,需要的朋友可以参考下
    2016-11-11
  • CentOS安装MySQL5.5的完整步骤

    CentOS安装MySQL5.5的完整步骤

    MySQL是最流行的关系型数据库管理系统之一,在 WEB 应用方面MySQL是最合适的数据库,这篇文章主要给大家介绍了关于CentOS安装MySQL5.5的相关资料,需要的朋友可以参考下
    2021-11-11
  • MySQL8.0找不到my.ini如何解决

    MySQL8.0找不到my.ini如何解决

    在配置MySQL主从复制时,发现找不到my.ini配置文件,通过检查路径和打开隐藏文件夹,最终在C:\ProgramData\MySQL\MySQLServer8.0目录下找到了my.ini文件
    2025-01-01
  • 一文简单了解MySQL前缀索引

    一文简单了解MySQL前缀索引

    MySQL是支持前缀索引的,也就是说你可以定义字符串的一部分作为索引,下面这篇文章主要给大家介绍了关于MySQL前缀索引的相关资料,需要的朋友可以参考下
    2022-04-04
  • 一文彻底搞懂MySQL TimeStamp时区问题

    一文彻底搞懂MySQL TimeStamp时区问题

    MySQL的timestamp类型默认使用的是服务器的时区来存储时间值,这意味着如果服务器的时区发生了变化,那么存储的timestamp值也会发生变化,下面这篇文章主要给大家介绍了关于如何通过一文彻底搞懂MySQL TimeStamp时区问题的相关资料,需要的朋友可以参考下
    2024-01-01

最新评论