JDBC连接MySql时报错:Exception in thread "main" java.sql.SQLException: The server time zone value '???ú±ê×

本文解决在使用JDBC连接MySQL8.0数据库时出现的“Couldnotcreateconnectiontodatabaseserver”错误。主要原因是驱动类名及URL参数配置不当。正确的驱动类名应为“com.mysql.cj.jdbc.Driver”,URL应包含字符集、时区和SSL等参数。

JDBC连接数据库是报错:Could not create connection to database server。或如题示报错。如图所示:
在这里插入图片描述

在这里错误的参数配置如下:

driverClassName:com.mysql.jdbc.Driver
url:jdbc:mysql://localhost:3306/test
username:root
password:12345678 

MySQL8.0版本需要更换驱动为“com.mysql.cj.jdbc.Driver”,之前的“com.mysql.jdbc.Driver”已经不能在MySQL 8.0版本使用了。
然后将url改成: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8&useSSL=false 即可。
配好之后打印连接如图所示就说明连接成功:
在这里插入图片描述

"D:\Program Files\Java\jdk-21\bin\java.exe" "-javaagent:D:\Program Files\JetBrains\IntelliJ IDEA 2025.1.2\lib\idea_rt.jar=50688" -Dfile.encoding=UTF-8 -Dsun.stdout.encoding=UTF-8 -Dsun.stderr.encoding=UTF-8 -classpath D:\2025小学期java项目\JDBC\target\classes;D:\2025小学期java项目\JDBC\src\main\lib\mysql-connector-java-8.0.18.jar com.itheimajdbc.JDBCDemo Exception in thread "main" 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:129) at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97) at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:89) at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:63) at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:73) at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:76) at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:836) at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:456) at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:246) at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:199) at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:683) at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:230) at com.itheimajdbc.JDBCDemo.main(JDBCDemo.java:19) Caused by: com.mysql.cj.exceptions.InvalidConnectionAttributeException: 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 java.base/jdk.internal.reflect.DirectConstructorHandleAccessor.newInstance(DirectConstructorHandleAccessor.java:62) at java.base/java.lang.reflect.Constructor.newInstanceWithCaller(Constructor.java:502) at java.base/java.lang.reflect.Constructor.newInstance(Constructor.java:486) at com.mysql.cj.exceptions.ExceptionFactory.createException(ExceptionFactory.java:61) at com.mysql.cj.exceptions.ExceptionFactory.createException(ExceptionFactory.java:85) at com.mysql.cj.util.TimeUtil.getCanonicalTimezone(TimeUtil.java:132) at com.mysql.cj.protocol.a.NativeProtocol.configureTimezone(NativeProtocol.java:2121) at com.mysql.cj.protocol.a.NativeProtocol.initServerSession(NativeProtocol.java:2145) at com.mysql.cj.jdbc.ConnectionImpl.initializePropsFromServer(ConnectionImpl.java:1310) at com.mysql.cj.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:967) at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:826) ... 6 more 进程已结束,退出代码为 1 出现什么错误了
最新发布
07-03
我的代码package hotel; import java.sql.Connection; import java.sql.DriverManager; import java.sql.Statement; /**jdbc快速入门demo*/ public class JDBCDemo2 { public static void main(String[] args) throws Exception { // Class.forName("com.mysql.jdbc.Driver"); //注册驱动 String url ="jdbc:mysql://127.0.0.1:3306/hotel?useSSL=false"; String username = "root"; String password = "Lqh2005320"; //获取链接 Connection conn = DriverManager.getConnection(url,username,password); //执行sql语句 String sql= "update room set stock = 15where id = 1"; Statement stmt = conn.createStatement();//获取对象statement int count = stmt.executeUpdate(sql); } } 出现错误D:\程序\bin\java.exe "-javaagent:C:\Users\moon\IntelliJ IDEA 2024.1.1\lib\idea_rt.jar=3640:C:\Users\moon\IntelliJ IDEA 2024.1.1\bin" -Dfile.encoding=UTF-8 -Dsun.stdout.encoding=UTF-8 -Dsun.stderr.encoding=UTF-8 -classpath D:\tem\jdbc\out\production\jdbc-demo;D:\tem\jdbc\jdbc-demo\lib\mysql-connector-java-8.0.11.jar hotel.JDBCDemo2 Exception in thread "main" java.sql.SQLException: The server time zone value 'Öйú±ê&times;¼Ê±¼ä' 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 java.sql/java.sql.DriverManager.getConnection(DriverManager.java:683) at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:230) at hotel.JDBCDemo2.main(JDBCDemo2.java:15) Caused by: com.mysql.cj.exceptions.InvalidConnectionAttributeException: The server time zone value 'Öйú±ê&times;¼Ê±¼ä' 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 java.base/jdk.internal.reflect.DirectConstructorHandleAccessor.newInstance(DirectConstructorHandleAccessor.java:62) at java.base/java.lang.reflect.Constructor.newInstanceWithCaller(Constructor.java:502) at java.base/java.lang.reflect.Constructor.newInstance(Constructor.java:486) at com.mysql.cj.exceptions.ExceptionFactory.createException(ExceptionFactory.java:59) at com.mysql.cj.exceptions.ExceptionFactory.createException(ExceptionFactory.java:83) at com.mysql.cj.util.TimeUtil.getCanonicalTimezone(TimeUtil.java:128) at com.mysql.cj.protocol.a.NativeProtocol.configureTimezone(NativeProtocol.java:2201) at com.mysql.cj.protocol.a.NativeProtocol.initServerSession(NativeProtocol.java:2225) at com.mysql.cj.jdbc.ConnectionImpl.initializePropsFromServer(ConnectionImpl.java:1391) at com.mysql.cj.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:993) at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:852) ... 6 more 进程已结束,退出代码为 1
03-29
### 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]。 以上四种途径任选其一均可有效规避因不明晰之故而引发的相关错误提示信息。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值