首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >团结一心

团结一心
EN

Stack Overflow用户
提问于 2018-07-06 16:32:40
回答 1查看 3.6K关注 0票数 0

我有两张桌子:

用户(这里有一个updated_at列)和user_updates (它有一个给用户的外键user_id和一个created_at列)

我想为用户找到最新的用户更新,所以我有以下内容:

代码语言:javascript
复制
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做一个协同工作。我试过这样做:

代码语言:javascript
复制
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子句中,或者用于聚合函数“。

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

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-07-06 16:34:16

通过在COALESCE函数中使用MAX

代码语言:javascript
复制
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
;
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51214498

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档