问题描述
每当您开始考虑要本地化的GROUP BY时,都应该开始考虑窗口函数。
我认为您正在追求这样的事情:
select unit_id, time, diag
from (
select unit_id, time, diag,
rank() over (partition by unit_id order by time desc) as rank
from diagnostics.unit_diag_history
) as dt
where rank = 1
您可能想在ORDER BY中添加一些内容以一贯打破关系,但这并不会改变整体技术。
解决方法
我有一个简单的表,其中包含unit_id oid,时间时间戳,diag bytea。主键是time和unit_id的组合。
该查询的目的是为每个唯一的unit_id获取最新的行(最大的时间戳)。但是,并非总是返回每个具有最新时间的unit_id的行。
我真的只想按unit_id进行分组,但是postgres也使我也使用了diag,因为我正在选择它。
SELECT DISTINCT ON(unit_id) max(time) as time,diag,unit_id
FROM diagnostics.unit_diag_history
GROUP BY unit_id,diag