创建没有timeZone的时间戳

时间:2011-12-28 11:40:39

标签: java jdbc timezone timestamp

如何创建没有时区的java.sql.timestamp(我正在2007-09-23T10:10:10Z并假装2007-09-23T10:10:10)。

我试试:

Timestamp timestamp = Timestamp.valueOf("2007-09-23 10:10:10");

但是在调试中我看到cdate是2007-09-23T10:10:10.000+0100而不是2007-09-23T10:10:10

2 个答案:

答案 0 :(得分:13)

时间戳没有时区。当您将时间戳显示为字符串时,它会显示时间并提及时区,因为否则您无法知道它代表的时间。它选择使用默认时区(你的),因为那是你最熟悉的时区。

说,它是12:00:00并不意味着什么。在你的时区说它是12:00:00意味着什么。但时间戳只包含一个及时的时间。您可以使用DateFormat在任何时区显示此瞬间。

注意:Timestamp.valueOf("2010-10-23 12:05:16");表示“在默认时区内使用给定时间创建时间戳”。

答案 1 :(得分:1)

tl; dr

  

…我可以创建一个没有时区的java.sql.timestamp…

不,您不能。班级错误。请改用java.time.LocalDateTime

详细信息

java.sql.Timestamp是使用错误的类。它代表了UTC中具有纳秒分辨率的时刻。

如果您想要一个带有日期时间的日期,而不考虑时区或从UTC偏移(所以,不是一刻),请使用另一个适合的类。

顺便说一句……java.sql.Timestamp是一个糟糕的,设计不好的旧类,几年前被java.time.Instant类(始终在UTC中)或java.time.OffsetDateTime(如果设置为UTC的偏移量。

LocalDateTime

具有日期时间(没有任何时区或UTC偏移量概念)的日期的正确类别是LocalDateTime

如上所述,这意味着该类是不是片刻,不是是时间线上的一点,应该使用 not 来跟踪某个地方发生事件的实际时间点。

TIMESTAMP WITHOUT TIME ZONE

在符合SQL标准的数据库中,例如Postgres,请使用数据类型为TIMESTAMP WITHOUT TIME ZONE(而不是WITH类型的列)。

LocalDateTime ldt = myResultSet.getObject( … , LocalDateTime.class ) ;

然后……

myPreparedStatement.setObject( … , ldt ) ;

关于 java.time

java.time框架已内置在Java 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.DateCalendarSimpleDateFormat

目前位于Joda-Timemaintenance mode项目建议迁移到java.time类。

要了解更多信息,请参见Oracle Tutorial。并在Stack Overflow中搜索许多示例和说明。规格为JSR 310

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

在哪里获取java.time类?

ThreeTen-Extra项目使用其他类扩展了java.time。该项目为将来可能在java.time中添加内容提供了一个试验场。您可能会在这里找到一些有用的类,例如IntervalYearWeekYearQuartermore