解决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的办法)
总结
这四种办法总有一种可以成功,以前的版本的没有时区问题,遇到了就总结下来了。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
关于maven install报错原因揭秘:parent.relativePath指向错误的本地POM文件
在使用Maven进行项目构建时,如果遇到'parent.relativePath'指向错误的本地POM文件的问题,可能会导致构建失败,这通常是由于父项目POM文件的相对路径设置错误、本地POM文件与父项目POM文件版本或内容不一致所致,解决方法包括检查并修正父项目POM文件中的相对路径设置2024-09-09使用postman传递list集合后台springmvc接收
这篇文章主要介绍了使用postman传递list集合后台springmvc接收的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-08-08BUUCTF-easy java WEB-INF/web.xml泄露漏洞及其利用方式
这篇文章主要介绍了BUUCTF-easy java WEB-INF/web.xml泄露漏洞及其利用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-07-07
最新评论