数据库、服务间的时区问题

经常会遇到一个问题:时间不对,比正常时间多或者少几个小时,这种情况可能是时区问题导致的。

已知

  • 数据库时区:东八区
  • 虚拟机时区(服务):东八区
  • 服务器时区:东八区

问题

服务新增数据时,通过new Date()创建的时间,存入数据库后发现数据库中的时间小8个小时。

但是服务从数据库中查询出来的时间又是正常的

原因

出现问题的原因可能是:项目的数据库配置指定了serverTimezone=UTC

UTC时间为零时区的时间,比东八区时间慢8小时。当新增时间写入数据库时,得知指定的数据库时区为UTC,会先将时间转化为减8小时,再传到数据库,数据库得到的时间显然会少8小时

写入数据库流程:

  1. new Date()创建的时间时,得到服务器时间、服务器时区、虚拟机时区
  2. 比对虚拟机时区和服务器时区,转换服务器时间得到虚拟机时间
  3. 虚拟机时间写入数据库时,比对虚拟机时区和数据库时区(由项目的数据库配置指定serverTimezone=UTC),转换虚拟机时间的到数据库时间(此时的时间已经少了8小时),时间写入数据库

查询数据库流程:

  1. 查询数据库得到数据库时间(此时的时间已经少了8小时)
  2. 比对数据库时区(由项目的数据库配置指定serverTimezone=UTC)和虚拟机时区
    ,转换数据库时间得到虚拟机时间(此时的时间已经比数据库时间多了8小时,所以变成了正常时间)

关于UTC可参考文章:UTC时间、CST时间和GMT时间

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值