加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Postgresql在日期范围之间进行查询

发布时间:2020-12-13 16:44:50 所属栏目:百科 来源:网络整理
导读:我试图查询我的postgresql数据库返回结果,其中日期是在特定的月份和年份。换句话说,我想一个月 – 年的所有价值观。 我迄今为止所能做到的唯一方法是这样的: SELECT user_id FROM user_logs WHERE login_date BETWEEN '2014-02-01' AND '2014-02-28' 这个
我试图查询我的postgresql数据库返回结果,其中日期是在特定的月份和年份。换句话说,我想一个月 – 年的所有价值观。

我迄今为止所能做到的唯一方法是这样的:

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

这个问题是,我必须计算查询表之前的第一个日期和最后一个日期。有更简单的方法吗?

谢谢

使用日期(和时间),如果您使用> = start AND<结束。 例如:
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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读