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

本文详细介绍了在使用SpringBoot连接MySQL数据库时遇到的时区问题及四种解决方案,包括指定低版本驱动、修改配置文件、设置JDBCURL时区和使用MySQL命令行调整。

在使用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的办法)
四、总结
这四种办法总有一种可以成功,以前的版本的没有时区问题,遇到了就总结下来了。

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

喵喵@香菜

感谢观众老爷送的一发火箭!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值