java.sql.Timestamp 时区是否特定?
背景:
JDBC 的 setTimestamp( int parameterIndex, Timestamp x) 方法为数据库列分配时间戳,无需显式指定时区。这就提出了一个问题:Timestamp 是否携带时区信息?
答案:
不,java.sql.Timestamp 本身并不携带时区信息。
说明:
通话时setTimestamp(...),JDBC 驱动程序依赖运行应用程序的虚拟机的时区来确定要存储的日期和时间。这意味着存储的值不会保留时区信息。
示例:
考虑以下场景:
在这种情况下,驱动程序会将 UTC 时间转换为 IST(基于虚拟机的时区)并将其存储为“20121225 12:00:00”
在特定时区存储时间戳:
要在特定时区存储时间戳,请使用 setTimestamp(int parameterIndex, Timestamp x, Calendar cal) 方法。指定具有所需时区的日历对象,以确保相应地存储时间戳。
其他注意事项:
以上是`java.sql.Timestamp` 是否存储时区信息?的详细内容。更多信息请关注PHP中文网其他相关文章!