首页 > 解决方案 > 与 group by 合并

问题描述

我有这两张表:

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. 我试过这个:

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 子句中或在聚合函数中使用”

我怎样才能解决这个问题?

标签: sqlpostgresql

解决方案


通过COALESCEMAX函数内部使用:

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
;

推荐阅读