首页 > Java > java教程 > `java.sql.Timestamp` 是否存储时区信息?

`java.sql.Timestamp` 是否存储时区信息?

Barbara Streisand
发布: 2024-12-24 19:09:13
原创
870 人浏览过

Does `java.sql.Timestamp` Store Time Zone Information?

java.sql.Timestamp 时区是否特定?

背景:

JDBC 的 setTimestamp( int parameterIndex, Timestamp x) 方法为数据库列分配时间戳,无需显式指定时区。这就提出了一个问题:Timestamp 是否携带时区信息?

答案:

不,java.sql.Timestamp 本身并不携带时区信息。

说明:

通话时setTimestamp(...),JDBC 驱动程序依赖运行应用程序的虚拟机的时区来确定要存储的日期和时间。这意味着存储的值不会保留时区信息。

示例:

考虑以下场景:

  • 应用程序时区:印度标准时间 (IST)
  • 数据库时区: IST
  • 时间戳值:“20121225 10:00:00 UTC”

在这种情况下,驱动程序会将 UTC 时间转换为 IST(基于虚拟机的时区)并将其存储为“20121225 12:00:00”

在特定时区存储时间戳:

要在特定时区存储时间戳,请使用 setTimestamp(int parameterIndex, Timestamp x, Calendar cal) 方法。指定具有所需时区的日历对象,以确保相应地存储时间戳。

其他注意事项:

  • 检索:何时使用 getTimestamp(...) 检索时间戳,驱动程序将使用虚拟机的时区来解释该值,除非是 Calendar 对象已指定。
  • java.time.LocalDateTime: 兼容 JDBC 4.2 的驱动程序支持 TIMESTAMP 数据的 java.time.LocalDateTime。这允许直接映射时间戳而无需时区转换。

以上是`java.sql.Timestamp` 是否存储时区信息?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板