Java和MySQL时间存储问题

本文探讨了Java时间API(如LocalDateTime, LocalDate, LocalTime, OffsetDateTime等)与MySQL数据库中时间类型的对应关系,强调了在不同时区环境下可能遇到的问题,特别是MySQL的DateTime和Timestamp类型的局限性。文章提醒开发者在处理时间存储时要注意时区转换和类型选择,以避免数据不一致。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Java和MySQL时间存储问题

巴拉巴拉一大堆

对应关系:

  • java.time.LocalDateTime ,无时区日期时间(显示值即值,没有内部值,对应的现实时间随时区浮动),JDBC 类型是TIMESTAMP ;
  • java.time.LocalDate ,无时区日期(显示值即值,没有内部值,与现实时间没有直接对应关系),JDBC 类型是 Date ;
  • java.time.LocalTime ,无时区当天时间(显示值即值,没有内部值,对应的现实时间随时区+天浮动),JDBC 类型是Time ;
  • java.time.OffsetDateTime ,偏移量日期时间(对应现实完整时间,内部值固定,显示值随时区偏移),JDBC 类型是TIMESTAMP ;
  • java.time.OffsetTime ,偏移量当天时间(对应现实当天时间,内部值固定,显示值随时区偏移),JDBC 类型是TIMESTAMP ;
  • java.time.ZonedDateTime ,基本等同于 OffsetDateTime ,区别只是一个是 CST时区,一个是+/-数字时区。

详细可见(英文文档) :Hibernate 提供的 BasicTypes->Java 8 BasicTypes 中的表 2 。

注意:

  • 上面的 Date 、Time 、TIMESTAMP 都是 JDBC 类型,具体是什么类型取决于各数据库厂商提供的 JDBC 驱动。另外TIMESTAMP 是时间戳 + 时区,不是只有时间戳。
  • 这里面 Mysql 提供了个狗屎。它的 DateTime 只是歪打正着的跟 java.time.LocalDateTime 对应,但也只在JVM 时区跟 数据库时区一致的情况下才这样,不一致的时候要出问题。而它的 Timestamp 则完全无法使用。

大佬解读:V2EX中“nothingistrue”的回复

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值