连接MySql报错(时区错误)——The server time zone value "" is unrecognized or represents more t...

在使用SpringBoot创建并启动项目时,出现的一个SqlSQLException。经查验,该问题是MySql本身的时区设置的问题导致的。完整的异常信息如下:

java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents morethan one time zone. 
You must configure either the server or JDBC driver
(via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.

/**
*谷歌翻译(英文是真的垃圾,唉):
java.sql.SQLException:服务器时区值'Öйú±ê׼ʱ¼ä'无法识别或代表多个时区。 
如果要使用时区支持,则必须配置服务器或JDBC驱动程序(通过serverTimezone配置属性)以使用更具体的时区值。
**/

MySql安装默认设置为美国时区,而北京时间比美国迟8小时。解决方法也很简单:

如果安装MySql时没有更改过默认安装路径,那么在默认的安装路径下C:\ProgramData\MySQL\MySQL Server 8.0找到my.ini文件。

服务安装地址.png


[mysqld]下方添加: default-time-zone='+08:00'(注意引号)

修改位置.png

 

因为是在springboot项目启动时报的,与mysql连接有关的错,找到了另外一种解决错误的方式

# 数据库基本配置
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/jpaLearn?serverTimezone=UTC&characterEncoding=utf8&useUnicode=true&useSSL=false
spring.datasource.username=sunyu
spring.datasource.password=sunyu

spring.datasource.url 这个配置中多加了 serverTimezone=UTC

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值