关于springboot项目中使用mysql存取日期不一致问题

问题描述:

         在做一个springboot前后端分离项目的时候,有一个实体类含有日期属性,在对这个实体类进行存取操作时发现存进的日期也不对,取出的日期也不对。

产生原因分析:

         前后端分离项目需要对返回的对象进行json格式转换,我用的是springboot自身集成的jackson,配置jackson对Date类型数据转换的格式和东八时区,但是mysql还是默认的时区。同过查阅得知,mysql日期类型数据底层还是以时间戳的形式存储的,所以对于日期数据,mysql和jackson按照不同的时区处理,最终显示的时间不同。

解决:

 先来一张说明图:

     

上图可知在jackson与mysql转换中有多个地方可导致存取时间问题。

1. mysql为默认时区,Jackson设置为GMT+8时区,结果是存的时间跟mysql显示的时间不一致,但是取出来的时间跟之前存进去的时间一致,跟mysql显示的时间不一致,mysql时间比存入的时间慢8个小时。

2.mysql为默认时区,Jackson也为默认时区,结果存取的时间一样。

3.mysql设置为GMT+8时区,Jackson为默认时区,结果是存的时间跟mysql显示的时间不一致,但是取出来的时间跟之前存进去的时间一致,跟mysql显示的时间不一致,mysql时间比存入的时间快8个小时。

4.mysql设置为GMT+8时区,Jackson也为GMT+8时区,结果存取的时间一样。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值