如何为每个 ID 获取具有 max(TIMESTAMP) 的行? [复制]

Posted

技术标签:

【中文标题】如何为每个 ID 获取具有 max(TIMESTAMP) 的行? [复制]【英文标题】:How to get for every ID the row with max(TIMESTAMP)? [duplicate] 【发布时间】:2021-10-30 22:34:59 【问题描述】:

我有以下简单的选择语句:

SELECT ID, EVENT, TIMESTAMP from table
order by ID, TIMESTAMP;

我现在只想为每个 ID 获取带有最后一个时间戳的条目,即带有 max(TIMESTAMP) 的条目。我怎样才能得到这个?我必须使用子查询吗?

【问题讨论】:

【参考方案1】:

一种方法使用聚合:

select id, max(timestamp) as timestamp,
       max(event) keep (dense_rank first order by timestamp desc) as event
from t
group by id;

keep 语法是 Oracles(相当冗长)实现“第一个”聚合函数的方式。

【讨论】:

“相当冗长” - 与其他方式相反?我相信大多数其他数据库产品根本没有实现第一个/最后一个聚合(和分析)函数,更不用说语法了。

以上是关于如何为每个 ID 获取具有 max(TIMESTAMP) 的行? [复制]的主要内容,如果未能解决你的问题,请参考以下文章

使用 DB2,您如何为一列选择具有 MAX 的行,然后在同一张表的另一列的结果子集中选择具有 MAX 的行?

如何为网页中的每个注册显示自动递增的 id 值?

如何为 Yii 中的每个按钮分配动作?

如何为调用 API 的方法编写 JUnit 测试?

为没有子查询的已知其他几列选择具有 MAX(column) 的一行

如何为 Postgresql 中的所有数据库创建具有只读权限的用户?