java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > java.sql.SQLException:The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized

解决java.sql.SQLException:The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized问题

作者:喵喵@香菜

这篇文章主要介绍了解决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的办法)

总结

这四种办法总有一种可以成功,以前的版本的没有时区问题,遇到了就总结下来了。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文