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

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: 这个错误提示意思是:服务器时区值“Öйú±ê&times;¼Ê±¼ä”无法识别或表示多个时区。如果您想使用时区支持,您必须配置服务器或JDBC驱动程序(通过servertimezone配置属性)以使用更具体的时区值。 这通常发生在使用JDBC连接到数据库时,服务器和客户端的时区不一致导致的。要解决这个问题,您可以在连接字符串中指定时区或在代码中通过设置时区属性来指定时区。例如,在连接字符串中添加“&servertimezone=UTC”指定时区为协调世界时(UTC);或者在代码中调用“TimeZone.setDefault(TimeZone.getTimeZone("UTC"))”来设置默认时区为UTC。 ### 回答2: 这是一个Java程序抛出的异常,意思是服务器时间区的值无法识别或表示多个时区。在使用Java程序连接数据库时,需要设置正确的时区值,因为数据库中有许多涉及时间的操作,如时间戳和日期函数。如果时区值不正确,程序在处理时间时会出现问题,导致程序失败或产生误差。 因此,要解决这个问题,有两种方法。一种是在服务器端配置正确的时区,另一种是在程序中配置JDBC驱动的servertimezone属性以使用更特定的时区值。 在服务器端配置时区需要了解服务器所在的位置和使用的操作系统。在Linux系统中,可以通过命令行输入timedatectl命令查看和设置时区。在Windows系统中,可以通过更改时区设置。 在程序中配置servertimezone属性需要使用JDBC驱动。可以在创建数据库连接时设置该属性,例如: String url = "jdbc:mysql://localhost:3306/mydatabase?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=Asia/Shanghai"; Connection conn = DriverManager.getConnection(url, "username", "password"); 这里的serverTimezone属性设置为“Asia/Shanghai”表示使用上海时区。需要根据实际情况设置时区值。 总之,正确配置时区值非常重要,可以避免在处理时间时产生错误,保证程序正确运行。 ### 回答3: 这个问题其实是由于数据库连接中的时区设定不明确所导致的。当我们在使用 JDBC 连接 MySQL 数据库时,如果无法识别或者存在多个可能时区的情况,就会提示 Server TimeZone Value 无法识别或表示超过一个时区。同时,提出了两种解决方法:一种是在 JDBC 配置文件中明确指定时区信息;另一种是在连接数据库时,将时区信息传递给服务器来解决这一问题。 针对这个问题,我们可以采用如下的步骤来解决: 1. 在 JDBC 配置文件中显式地指定时区信息 在 JDBC 连接MySQL数据库时,在连接字符串中添加serverTimezone属性,并指定所需要的时区信息(如下例中的GMT)。这样一来,就可以明确指定时区信息,避免发生 Server TimeZone Value 不明确的情况。 ``` String url = "jdbc:mysql://localhost:3306/mydatabase?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT"; ``` 2. 将时区信息传递给数据库服务器 在创建 JDBC 数据库连接的时候,我们可以使用下面的代码来设置时区信息。这样一来,就可以将时区信息传递给数据库服务器,从而解决 Server TimeZone Value 不明确的问题。 ``` Connection conn = DriverManager.getConnection(url, username, password); Statement stmt = conn.createStatement(); stmt.execute("SET time_zone = '+8:00'"); ``` 总之,无论是采用哪种解决方法,都需要我们显式地指定时区信息,才能避免 Server TimeZone Value 不明确或表示过多时区的情况,从而保证 JDBC 时区支持的有效性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

喵喵@香菜

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

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

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

打赏作者

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

抵扣说明:

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

余额充值