jpa或者mybatis中mysql保存日期相差8个、13或14小时

问题描述
通过jpa或者mybatis插入数据库发现数据的日期格式字段与服务器时间相差8个、13个或者14个小时。但是通过navicat直接insert语句不会出现该情况。
在数据库查询时区
show variables like "%time_zone%";
原因
如上图,可以看到数据库使用的系统的CST,那么这里的CST到底是哪里的时区呢,请看下面:
- 美国中部时间:Central Standard Time (USA) UT-6:00
- 澳大利亚中部时间:Central Standard Time (Australia) UT+9:30
- 中国标准时间:China Standard Time UT+8:00
- 古巴标准时间:Cuba Standard Time UT-4:00
CST 的时区是一个很混乱的时区,在与 MySQL 协商会话时区时,Java 会误以为是 CST -0500,而非 CST +0800
解决方法
jdbc.url=jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true
方法一
在数据库连接字符串添加 &serverTimezone=GMT%2b8
方法二
在数据库连接url后添加参数 &serverTimezone=Asia/Shanghai
即可