如何为每个 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 的行?