java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized...

https://blog.csdn.net/zwj1030711290/article/details/81190635

今天又遇到了这个错误,每次都要去寻找错误原因非常得浪费时间,所以决定以后遇到了问题之后都到这里来记录一下错误。

 
  1. 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.

  2. at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:127)

  3. at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:95)

  4. at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:87)

  5. at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:61)

  6. at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:71)

  7. at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:76)

  8. at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:862)

  9. at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:444)

  10. at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:230)

  11. at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:226)

  12. at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1558)

  13. at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1623)

  14. at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2468)

  •  

这是在使用MySQL 8.0以上版本(MySQL连接驱动和版本都是8.0以上)的时候出现的问题错误,我们需要在访问数据库的Url后面加上以下的语句即可:

?serverTimezone=GMT%2B8
  •  

比如,我原来的url是:

"jdbc:mysql://localhost:3306/shiro_test"
  •  

应该修改为:

"jdbc:mysql://localhost:3306/shiro_test?serverTimezone=GMT%2B8"
  •  

从错误上看应该是时区的错误,所以我们只需要设置完毕系统的时区即可。这里的GMT%2B8代表东八区。

还有一种解决办法就是设置整个数据库的时区,可以执行下面的语句来完成:

 
  1. show variables like '%time_zone%'

  2. set global time_zone='+8:00';

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值