首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PostgreSQL与TSTZRANGE

PostgreSQL与TSTZRANGE
EN

Stack Overflow用户
提问于 2020-04-19 06:18:59
回答 1查看 1.7K关注 0票数 0

我对使用日期时间范围非常陌生,在查看了文档之后,我感到困惑的是,为什么以下简单的查询没有像我预期的那样进行:

寿命= DateTimeRangeField

代码语言:javascript
复制
select id, lifespan 
from companyfeatures
where lifespan && TSTZRANGE('1 Mar 2020', '1 May 2020')

我原以为结果只是那些寿命介于“2020年3月1日”至“2020年5月1日”之间的记录--然而,结果包括寿命为零的记录。

有人能帮我解释我哪里出了问题吗?

编辑:谢@a_horse_with_no_name --在挖掘了更多内容之后,看来寿命字段之前已经填充了“空”或默认范围--即DateTimeTZRange(无,无,'()') --因此它们不是空的。非常混乱,我无法改变(在这个阶段)。因此,我正在寻找一种方法,以找到重叠(有共同点)与我的特定范围日期,而忽略‘空’的?你能帮忙吗?

[医]小提琴

EN

回答 1

Stack Overflow用户

发布于 2020-04-19 11:39:05

您可以在WHERE子句中筛选这些

代码语言:javascript
复制
select id, lifespan 
from companyfeatures
where upper(lifespan) IS NOT NULL 
  and lower(lifespan) IS NOT NULL
  and lifespan && TSTZRANGE('2020-03-01', '2020-05-01')
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61300341

复制
相关文章

相似问题

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