首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在postgres中获取两个时间戳之间的所有数据。

如何在postgres中获取两个时间戳之间的所有数据。
EN

Stack Overflow用户
提问于 2018-10-14 20:14:04
回答 1查看 207关注 0票数 0

开始时间--> 10月14 10 pm结束时间--> 10月14 11 pm如果我传递一个值为"oct 14 10:30 pm“,则我必须将其开始时间大于传递的值、结束时间小于传递的值的所有行

EN

回答 1

Stack Overflow用户

发布于 2018-10-14 23:17:24

tl;dr

使用半开放方法,>= AND <逻辑,对于时间跨度,而不是BETWEEN

错误的逻辑

开始时间--> 10月14日10 pm结束时间--> 10月14日11 pm…然后,我必须处理开始时间大于传递的值、结束时间小于传递的值的所有行

这个逻辑是不正确的。用这样的逻辑做这样的每小时报告,你将永远不会报告当时钟敲响一个小时时碰巧记录的项目。不会找到值正好在10 AM (10:00:00.0)或11 AM (11:00:00.0)的行。

半开

我建议一致地使用半开放方法来定义时间跨度。在这种方法中,开始是包容性的,而结尾是排他性的。例如,该小时从上午10点的第一个时刻开始,一直持续到(但不包括)时钟敲击上午11点

使用这种方法,我将提供一系列每小时一次的查询,查找所有行。任何行都不会像您的逻辑那样消失。

代码语言:javascript
复制
SELECT * 
FROM event_
WHERE when_ >= ?
AND when_ < ?
;

换句话说,从不将 BETWEEN与时间跨度一起使用。请改用>= AND <逻辑。

时区

如果要讨论实际时刻,如果要讨论TIMESTAMP WITH TIME ZONE的SQL标准列类型,则时区问题至关重要。

在你的例子中,你是指法国巴黎的上午10点吗?或者上午10点在魁北克省蒙特勒阿勒市,几个小时后?或者印度加尔各答上午10点,几个小时前?

在Java语言中,通过ZonedDateTime类将您的条件定义为使用时区的时刻。

代码语言:javascript
复制
ZoneId z = ZoneId.of( "Pacific/Auckland" ) ;
LocalDate ld = LocalDate.of( 2018 , 10 , 14 ) ;
LocalTime lt = LocalTime.of( 10 , 0 ) ;
ZonedDateTime zdt = ZonedDateTime.of( ld , lt , z ) ;

要查看以协调世界时为单位的相同时刻,请提取Instant

代码语言:javascript
复制
Instant instant = zdt.toInstant() ;

生成以标准ISO 8601格式表示其值的文本。

代码语言:javascript
复制
String output = instant.toString() ;   // Generate text in standard ISO 8601 format. 

使用与JDBC 4.2或更高版本兼容的JDBC驱动程序,在准备好的语句中将其传递给SQL查询。

代码语言:javascript
复制
myPreparedStatement.setObject( 1 , zdtStart ) ;
myPreparedStatement.setObject( 2 , zdtStop ) ;

关于java.time

框架内置于Java8和更高版本中。这些类取代了麻烦的旧legacy日期时间类,如java.util.DateCalendarSimpleDateFormat

现在在maintenance mode中的项目建议迁移到java.time类。

要了解更多信息,请参阅。和搜索堆栈溢出,以获得许多示例和解释。规范为JSR 310

您可以直接与数据库交换java.time对象。使用与JDBC 4.2或更高版本兼容的JDBC driver。不需要字符串,也不需要java.sql.*类。

从哪里获取java.time类?

  • ,、、和更高版本-标准Java API的一部分,具有捆绑的实现。
    • Java9添加了一些次要功能和fixes.

  • 和.

中的

  • 大多数java.time功能已向后移植到Java6和7

    • 更高版本的Android捆绑实现的java.time类。
    • 对于较早的Android (<26),项目适配 (如上所述)。请参阅.

项目使用额外的类扩展了java.time。这个项目是未来可能添加到java.time中的试验场。您可能会在这里找到一些有用的类,如IntervalYearWeekYearQuartermore

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52802522

复制
相关文章

相似问题

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