java设置数据生效时间_Java时间比数据库时间早8小时,设置 serverTimezone=Asia/Shanghai-Fun言...

前段时间把项目 SpringBoot 版本提高了,提高到了 2.1.7,之前版本不记得了。项目所有表都添加了 create_time 和 update_time 字段,并设置默认值为 CURRENT_TIMESTAMP。

有一天无意间发现网页上显示的时间,比如用户登录时间和数据库里显示不一样,页面上的早了几个小时。比如 当前时间是 2019-10-19 18:12:43,数据库时间也是 2019-10-19 18:12:43;但是页面缺显示 2019-10-20 02:12:43。

多对比几组时间分析,发现 Java 的时间总比数据库的早 8 个小时。

问题原因

导致整个问题的原因是之前的 mysql-connector-java 依赖没有指定版本,默认跟随 spring-boot-dependencies 里的版本,因为之前 springboot 版本相对低点,所以驱动版本是 5.1,没有暴露问题

但是升级到 2.1.7 后,里面默认指定 mysql-connector-java 版本为 8.0.17,这个我之前其实是知道的,springboot 高版本里的默认依赖都会相对更高。

总来来说:问题在 MySQL8.0的驱动包跟之前不一样了,默认时区是全球统一时间 (UTC),北京时间是 UTC+8。

解决办法

解决办法很简单,在 jdbc 驱动的 url 上加上

serverTimezone=Asia/Shanghai

如果不加 serverTimezone 或设置为 UTC 都是差 8 个小时,设置成为上海的时区就行。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值