解决java.sql.SQLException:The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized问题
作者:喵喵@香菜
在使用SpringBoot链接mysql数据库时遇到mysql时区问题,总结了三种方法
出现问题的环境
springBoot2.1.4+mysql数据库
出现问题的原因
SpringBoot2.1在没有指定MySQL驱动版本的情况下它自动依赖的驱动是8.0的版本,而在安装mysql数据库时一般都不会设置时区,系统默认的时区是美国,北京时间比美国时间晚8个小时。
所以出现了
The server time zone value ‘Öйú±ê׼ʱ¼ä’ is unrecognized …的问题。
解决办法总结
1)最low的办法,指定mysqlJDBC的低版本驱动。
如下:
<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.28</version> <scope>runtime</scope> </dependency>
使用maven的这样,手动导包的可直接导入低版本的jar包(手动导入后记得buildpath,并且删除不合适的版本)。
2)修改mysql配置文件;安装mysql默认路径一般都是在c盘,例如我的路径是:C:\Program Files\MySQL\MySQL Server 5.6,有一个my.ini(或者my-default.ini) 的配置文件。
打开配置文件修改如下(添加 default-time-zone=’+08:00’):
3)推荐使用第三种:将jdbcurl连接设置时区;
spring.datasource.jdbc-url: jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8
如果是在代码中耦合的,直接改代码中的地址即可
4)使用cmd:(安装mysql默认会将mysql配置到环境变量的path从而可以执行cmd命令) 使用mysql命令登录mysql
mysql -uroot -p******
登录成功后输入show variables like ‘%time_zone%’;
这里的system是系统默认的时区,即美国时间
输入 set global time_zone=’+8:00’; (输入完毕后进行检查)再次输入show variables like ‘%time_zone%’;
(ps;不一定成功,我自己测试没有成功,选择的配置jdbcurl的办法)
总结
这四种办法总有一种可以成功,以前的版本的没有时区问题,遇到了就总结下来了。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。