小编典典

日期范围之间的 Postgresql 查询

all

我正在尝试查询我的 postgresql 数据库以返回日期在某个月份和年份的结果。换句话说,我想要一个月的所有值。

到目前为止,我能够做到的唯一方法是这样的:

SELECT user_id 
FROM user_logs 
WHERE login_date BETWEEN '2014-02-01' AND '2014-02-28'

问题是我必须在查询表之前计算第一个日期和最后一个日期。有没有更简单的方法来做到这一点?

谢谢


阅读 129

收藏
2022-08-07

共1个答案

小编典典

有了日期(和时间),如果你使用>= start AND < end.

例如:

SELECT
  user_id
FROM
  user_logs
WHERE
      login_date >= '2014-02-01'
  AND login_date <  '2014-03-01'

在这种情况下,您仍然需要计算所需月份的开始日期,但这应该以多种方式直接进行。

结束日期也被简化;只需添加一个月。28 日、30 日、31 日等不要乱搞。

这种结构还具有能够保持索引使用的优点。

许多人可能会建议如下形式,但他们 使用索引:

WHERE
      DATEPART('year',  login_date) = 2014
  AND DATEPART('month', login_date) = 2

这涉及计算表中每一行的条件(扫描),而不是使用索引来查找将匹配的行范围(范围搜索)。

2022-08-07