首页 > 数据库 > mysql教程 > 如何为 SQL 中的每个键选择最近的时间戳行?

如何为 SQL 中的每个键选择最近的时间戳行?

Barbara Streisand
发布: 2024-12-17 16:45:11
原创
426 人浏览过

How to Select the Most Recent Timestamped Row for Each Key in SQL?

为每个键值选择最新的时间戳行

在管理多个条目的数据时,通常需要识别和检索包含最新时间戳的记录给定的密​​钥。虽然简单的方法可能涉及按键分组并按最大时间戳排序,但这可能会导致与未出现在 group by 子句中的字段相关的错误。

为了克服此问题,另一种查询结构提供了可行的解决方案:

SELECT sensorID,
       timestamp,
       sensorField1,
       sensorField2
FROM sensorTable s1
WHERE timestamp = (
    SELECT MAX(timestamp)
    FROM sensorTable s2
    WHERE s1.sensorID = s2.sensorID
)
ORDER BY sensorID, timestamp;
登录后复制

此查询本质上将sensorTable s1中的每一行与其在sensorTable s2中最新带时间戳的对应行进行匹配。 WHERE 子句有效地过滤掉除每个键具有最大时间戳的行之外的所有行,确保所选数据是最新的。通过按传感器 ID 对结果进行分组并按时间戳排序,查询将返回一行,其中包含每个键的最新时间戳以及所需的附加字段。

以上是如何为 SQL 中的每个键选择最近的时间戳行?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板