本文主要是介绍java.sql.SQLException: The server time zone value '???ú±ê×??±??' is unrecognized or represents more,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
注意:字里面的引号和 & 符号可能是中文的,有一点点不方便,自己稍微改一下。
1 报错代码:
加载类“com.mysql.jdbc.Driver”。这已被弃用。新的驱动程序类是`com.mysql.cj.jdbc.Driver'。驾驶员通过SPI自动注册和驱动程序类的
连接数据库...
星期六6月2日10时47分02秒CST 2018 WARN:建立无服务器的身份验证SSL连接不推荐使用。根据MySQL 5.5.45 +,5.6。 26+和5.7.6+的要求,如果未设置显式选项,则必须默认建立SSL连接。为了符合不使用SSL的现有应用程序,verifyServerCertificate属性设置为'false'。您需要通过设置useSSL = false显式禁用SSL,或者设置useSSL = true并为服务器证书验证提供信任库。java.sql.SQLException
:服务器时区值'???ê×?? ?? ??” 无法识别或代表多个时区。如果要利用时区支持,则必须配置服务器或JDBC驱动程序(通过serverTimezone配置属性)以使用更具体的时区值。在com.mysql.cj.jdbc.exceptions。 SQLError.createSQLException(SQLError.java:127)在com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:95)
2 错误截图:
3 工具版本:
mysql - 5.7.21
JDBC驱动:MySQL的的连接器的Java的8.0.11.jar
4 错误分析:
出现这种错误一般是JDBC驱动版本的原因
5错误1:
加载类“com.mysql.jdbc.Driver” 。这已被弃用。新的驱动程序类是`com.mysql.cj.jdbc.Driver' 驱动程序通过SPI自动注册,通常不需要手动加载驱动程序类。
解决方法:这个问题很简单按照它的提示把代码中com.mysql.jdbc.Driver改成com.mysql.cj.jdbc.Driver就可以了
修改前代码:
static final String JDBC_DRIVER =“com.mysql.jdbc.Driver”;
修改后代码:
static final String JDBC_DRIVER =“com.mysql.cj.jdbc.Driver”;
错误2:Sat Jun 02 11:40:45 CST 2018 WARN:建议不建立服务器身份验证的SSL连接。根据MySQL 5.5.45 +,5.6.26 +和5.7.6+的要求,如果未设置显式选项,则必须默认建立SSL连接。为了符合不使用SSL的现有应用程序,verifyServerCertificate属性设置为'false'。您需要通过设置useSSL = false显式禁用SSL,或者设置useSSL = true并且为服务器证书验证提供信任库。
解决方法:
这是一个警告 ,即在原来的数据库名称后面添加:?useUnicode=true&characterEncoding=utf-8&useSSL=false
修改前代码:
static final String DB_URL =“jdbc:mysql:// localhost:3306 / runoob”;
修改后代码:
static final String JDBC_DRIVER =“com.mysql.cj.jdbc.Driver”; static final String DB_URL =“jdbc:mysql:// localhost:3306 / runoob?useUnicode = true&characterEncoding = utf-8&useSSL = false”;
static final String DB_URL =“jdbc:mysql:// localhost:3306 / runoob?useUnicode = true&characterEncoding = utf-8&useSSL = false”;
错误3:
java.sql.SQLException中:服务器时区值'??? EE×??±??' 。无法识别或代表多个时区如果要利用时区支持,则必须配置服务器或JDBC驱动程序(通过serverTimezone配置属性)以使用更具体的时区值。
解决方法:
这是由于数据库和系统时区差异所造成的,在JDBC连接的URL后面加上serverTimezone = GMT即可解决问题,如果需要使用GMT + 8时区,需要写成GMT%2B8,否则会被解析为空。再一个解决办法就是使用低版本的MySQL jdbc驱动,
修改前代码:
static final String JDBC_DRIVER =“com.mysql.cj.jdbc.Driver”; static final String DB_URL =“jdbc:mysql:// localhost:3306 / runoob?useUnicode = true&characterEncoding = utf-8&useSSL = false”;
static final String DB_URL =“jdbc:mysql:// localhost:3306 / runoob?useUnicode = true&characterEncoding = utf-8&useSSL = false”;
修改后代码:
static final String JDBC_DRIVER =“com.mysql.cj.jdbc.Driver”; static final String DB_URL =“jdbc:mysql:// localhost:3306 / runoob?useUnicode = true&characterEncoding = utf-8&useSSL = false&serverTimezone = GMT“;
最后问题解决:
这篇关于java.sql.SQLException: The server time zone value '???ú±ê×??±??' is unrecognized or represents more的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!