与group by合并

时间:2018-07-06 16:32:40

标签: sql postgresql

我有这两个表:

users(此字段具有Updated_at列)和user_updates(此字段具有用户的外键user_id和created_at列)

我想为该用户找到最新的用户更新,所以我有这个:

SELECT user_id, MAX(user_updates.created_at) as last_update
FROM user_updates
WHERE user_id IN (<user_id>)
GROUP BY 1

但是,有时user_update没有created_at,所以我需要对users.updated_at进行COALLESCE。我已经尝试过了:

SELECT user_id, COALESCE(MAX(user_updates.created_at), users.updated_at) as last_update
FROM user_updates
INNER JOIN users ON users.id = user_updates.user_id
WHERE user_id IN (<user_id>)
GROUP BY 1

但是Postgres抱怨说:“列“ users.updated_at”必须出现在GROUP BY子句中或在聚合函数中使用“

我该如何解决?

1 个答案:

答案 0 :(得分:1)

通过在COALESCE函数内使用MAX

SELECT  user_id, 
        MAX(COALESCE(user_updates.created_at,users.updated_at)) as last_update
FROM user_updates
INNER JOIN users 
    ON users.id = user_updates.user_id
WHERE user_id IN (<user_id>)
GROUP BY user_id
;