如何创建没有时区的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
答案 0 :(得分:13)
时间戳没有时区。当您将时间戳显示为字符串时,它会显示时间并提及时区,因为否则您无法知道它代表的时间。它选择使用默认时区(你的),因为那是你最熟悉的时区。
说,它是12:00:00并不意味着什么。在你的时区说它是12:00:00意味着什么。但时间戳只包含一个及时的时间。您可以使用DateFormat在任何时区显示此瞬间。
注意:Timestamp.valueOf("2010-10-23 12:05:16");
表示“在默认时区内使用给定时间创建时间戳”。
答案 1 :(得分:1)
…我可以创建一个没有时区的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 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.Date
,Calendar
和SimpleDateFormat
。
目前位于Joda-Time的maintenance 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中添加内容提供了一个试验场。您可能会在这里找到一些有用的类,例如Interval
,YearWeek
,YearQuarter
和more。