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

问题描述:

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

产生原因分析:

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

解决:

 先来一张说明图:

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

上图可知在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时区,结果存取的时间一样。