解决MySQL报错The server time zone value 'Öйú±ê×¼Ê&#...

原文连接html

 

 

 

1.前言 

今天在用SpringBoot2.0+MyBatis+MySQL搭建项目开发环境的时候启动项目发现报了一个很奇怪的错,报错内容以下:java

java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than 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.
at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:127)
at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:95)
at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:87)
at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:61)
at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:71)
at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:76)
at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:862)
at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:444)
at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:230)
at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:226)
at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1558)
at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1623)
at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2468)

 


后来查阅资料发现这都是由于安装mysql的时候时区设置的不正确 mysql默认的是美国的时区,而咱们中国大陆要比他们迟8小时,采用+8:00格式mysql

 

使用的数据库是MySQL,从上面图看出SpringBoot2.1在你没有指定MySQL驱动版本的状况下它自动依赖的驱动是8.0.12很高的版本,这是因为数据库和系统时区差别所形成的,在jdbc链接的url后面加上serverTimezone=GMT便可解决问题,若是须要使用gmt+8时区,须要写成GMT%2B8,不然会被解析为空。再一个解决办法就是使用低版本的MySQL jdbc驱动,5.1.28不会存在时区的问题。 sql

2.解决办法 

 1.修改MySQL的配置文件,MySQL配置文件是my.ini文件在你的安装目录下去找,个人是在C:\Program Files (x86)\MySQL\MySQL Server 5.5\my.ini数据库

找到这个文件以后用Notepad++打开它,搜索[mysqld]节点在节点下面加上下面这句话ubuntu

default-time-zone='+08:00'app


而后记得重启MySQL的服务,打开cmd窗口登陆MySQL执行show variables like '%time_zone%';这句命令ui

 2.直接在mysql执行语句:url

set global time_zone='+8:00'

 

 

注意:如果在ubuntu环境下,直接在my.cnf文件中添加该行代码便可。spa

相关文章
相关标签/搜索