关于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时区,结果存取的时间一样。