今天又遇到了这个错误,每次都要去寻找错误原因非常得浪费时间,所以决定以后遇到了问题之后都到这里来记录一下错误。
-
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 8.0以上版本(MySQL连接驱动和版本都是8.0以上)的时候出现的问题错误,我们需要在访问数据库的Url后面加上以下的语句即可:
?serverTimezone=GMT%2B8
- 1
比如,我原来的url是:
"jdbc:mysql://localhost:3306/shiro_test"
- 1
应该修改为:
"jdbc:mysql://localhost:3306/shiro_test?serverTimezone=GMT%2B8"
- 1
从错误上看应该是时区的错误,所以我们只需要设置完毕系统的时区即可。这里的GMT%2B8
代表东八区。
还有一种解决办法就是设置整个数据库的时区,可以执行下面的语句来完成:
-
show variables like '%time_zone%'
-
set global time_zone='+8:00';