首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在postgresql中重用子查询

在postgresql中重用子查询
EN

Stack Overflow用户
提问于 2021-12-23 20:58:23
回答 1查看 221关注 0票数 0

我有一个运行良好的查询,但是我在其中使用了两次相同的子查询。我想知道是否有一种方法可以重用这个子查询。以下是查询:

代码语言:javascript
复制
SELECT DISTINCT homeworks.*
FROM homeworks
INNER JOIN homework_messages ON homeworks.id = homework_messages.homework_id
WHERE homework_messages.message_type = 'submit'
  AND homework_messages.created_at::date <= (CURRENT_DATE - '5 days'::interval)
  AND (
    (
      SELECT MAX(homework_messages.created_at) FROM homework_messages
      WHERE homework_messages.homework_id = homeworks.id AND homework_messages.message_type != 'submit'
    ) < homework_messages.created_at 
    OR 
    (
      SELECT MAX(homework_messages.created_at) FROM homework_messages
      WHERE homework_messages.homework_id = homeworks.id AND homework_messages.message_type != 'submit'
    ) IS NULL
  )
GROUP BY homeworks.id

如你所见,我重复了两遍:

代码语言:javascript
复制
(
  SELECT MAX(homework_messages.created_at) FROM homework_messages
  WHERE homework_messages.homework_id = homeworks.id AND homework_messages.message_type != 'submit'
)

我试着用WITH子句,它似乎不适合这个问题,或者我可能用错了。不管怎样,谢谢你的帮助。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-12-23 21:17:39

这是一个cross join lateral建议。我没有钻研你的业务逻辑,只是试着保持它的等价性。

代码语言:javascript
复制
SELECT DISTINCT homeworks.*
FROM homeworks
INNER JOIN homework_messages ON homeworks.id = homework_messages.homework_id
cross join lateral ( -- your subquery follows
  SELECT MAX(created_at) as created_at FROM homework_messages
  WHERE homework_id = homeworks.id AND message_type != 'submit'
) as lat
WHERE homework_messages.message_type = 'submit'
  AND homework_messages.created_at::date <= (CURRENT_DATE - '5 days'::interval)
  AND (lat.created_at < homework_messages.created_at OR lat.created_at IS NULL)
GROUP BY homeworks.id;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70467304

复制
相关文章

相似问题

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