java.sql.SQLException: The server time zone value '???ú±ê×??±??' is unrecognized or represents more

本文介绍了使用MySQL JDBC驱动过程中常见的三个错误及其解决方案,包括驱动加载、SSL连接警告及服务器时区值问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

注意:字里面的引号和 & 符号可能是中文的,有一点点不方便,自己稍微改一下。

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中关于服务器时区值不可识别或多义问题的解决方案 此问题是由于MySQL服务器返回的时间值无法被JDBC驱动程序正确解析所引起的。具体来说,JDBC驱动尝试解释来自数据库服务器的时间区域设置,但如果该时间区域名称不明确或者未被识别,则会抛出`java.sql.SQLException`异常。 #### 解决方案一:通过URL参数指定时区 可以通过在JDBC URL中显式定义`serverTimezone`参数来解决问题。例如: ```properties jdbc:mysql://localhost:3306/your_database?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC ``` 上述代码片段中的`serverTimezone=UTC`指定了统一协调世界时间作为默认时区[^1]。如果应用程序运行于其他地区,可以替换为相应的时区字符串(如`Asia/Shanghai`)。这样能够确保无论服务器端如何配置,客户端始终采用一致的时区处理逻辑。 #### 解决方案二:更新MySQL Connector/J版本 旧版MySQL JDBC驱动可能缺乏对某些新标准的支持,因此建议升级到最新稳定发布的MySQL Connector/J库文件。新版通常修复了大量已知缺陷并增强了兼容性特性[^2]。 #### 解决方案三:修改MySQL服务端全局变量time_zone 另一种方法是从根源上调整——即更改MySQL实例本身的缺省工作时区设定。执行如下SQL命令即可完成操作: ```sql SET GLOBAL time_zone = '+00:00'; -- 设置成UTC或其他固定偏移量形式 ``` 注意这一步骤需具备管理员权限才能生效,并且会影响整个DBMS的行为模式[^3]。 #### 解决方案四:忽略本地化差异 对于那些确实不需要考虑跨地域日期运算的应用场景而言,还可以简单粗暴地关闭所有与时区有关的功能开关选项。只需向连接串追加额外几个标志位即可达成目的: ```properties ... &useLegacyDatetimeCode=false &serverTimezone=GMT%2B8 ... ``` 这里特别强调的是第二个参数部分必须经过URLEncode编码转换才行[^4]。 以上四种途径任选其一均可有效规避因不明晰之故而引发的相关错误提示信息。
评论 46
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值