如果表中不存在行,则为空

时间:2018-07-06 17:10:32

标签: sql postgresql

我有这两个表:

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

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

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
;

只要user_updates存在user_id,就可以使用。但是,如果没有user_updates,我想返回users.updated_at。如何更改此查询?

我该如何解决?

2 个答案:

答案 0 :(得分:3)

似乎您需要left join来代替:

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

答案 1 :(得分:0)

尽管您可能会假设up.updated_at是在u.updated_at之后创建的,但我将逻辑写为:

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

这样可以使您更清楚地希望获得最大的用户更新日期,如果不存在,则为用户日期。