开始时间--> 10月14 10 pm结束时间--> 10月14 11 pm如果我传递一个值为"oct 14 10:30 pm“,则我必须将其开始时间大于传递的值、结束时间小于传递的值的所有行
发布于 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点
使用这种方法,我将提供一系列每小时一次的查询,查找所有行。任何行都不会像您的逻辑那样消失。
SELECT *
FROM event_
WHERE when_ >= ?
AND when_ < ?
;
换句话说,从不将 BETWEEN
与时间跨度一起使用。请改用>= AND <
逻辑。
时区
如果要讨论实际时刻,如果要讨论TIMESTAMP WITH TIME ZONE
的SQL标准列类型,则时区问题至关重要。
在你的例子中,你是指法国巴黎的上午10点吗?或者上午10点在魁北克省蒙特勒阿勒市,几个小时后?或者印度加尔各答上午10点,几个小时前?
在Java语言中,通过ZonedDateTime
类将您的条件定义为使用时区的时刻。
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
。
Instant instant = zdt.toInstant() ;
生成以标准ISO 8601格式表示其值的文本。
String output = instant.toString() ; // Generate text in standard ISO 8601 format.
使用与JDBC 4.2或更高版本兼容的JDBC驱动程序,在准备好的语句中将其传递给SQL查询。
myPreparedStatement.setObject( 1 , zdtStart ) ;
myPreparedStatement.setObject( 2 , zdtStop ) ;
关于java.time
框架内置于Java8和更高版本中。这些类取代了麻烦的旧legacy日期时间类,如java.util.Date
、Calendar
和SimpleDateFormat
。
现在在maintenance mode中的项目建议迁移到java.time类。
要了解更多信息,请参阅。和搜索堆栈溢出,以获得许多示例和解释。规范为JSR 310。
您可以直接与数据库交换java.time对象。使用与JDBC 4.2或更高版本兼容的JDBC driver。不需要字符串,也不需要java.sql.*
类。
从哪里获取java.time类?
中的
项目使用额外的类扩展了java.time。这个项目是未来可能添加到java.time中的试验场。您可能会在这里找到一些有用的类,如Interval
、YearWeek
、YearQuarter
和more。
https://stackoverflow.com/questions/52802522
复制相似问题