gpt4 book ai didi

java - 包 com.mysql.jdbc.exceptions.jdbc4 在 Mysql Connector/J 8 中不存在

转载 作者:塔克拉玛干 更新时间:2023-11-01 23:01:15 24 4
gpt4 key购买 nike

mysql-connector-java 版本 5.1.x 的 Maven 依赖项升级到 8.0.x 后,编译时收到以下错误:

[ERROR] /home/dev/testproject/src/main/java/DatabaseOperation.java:20: error: package com.mysql.jdbc.exceptions.jdbc4 does not exist
[ERROR] import com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException;

[ERROR] /home/dev/testproject/src/main/java/DatabaseService.java:15: error: package com.mysql.jdbc.exceptions.jdbc4 does not exist
[ERROR] import com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException;

显然 com.mysql.jdbc.exceptions.jdbc4 已被删除,没有任何弃用或迁移文档中的注释。现在有什么选择?

最佳答案

事实上,发行说明或迁移文档中没有提到这一点。我在 MySQL 论坛上找到了相关主题:Connector/J 8, catching primary key violations .这是那里的 MySQL 代表的回答:

You can catch java.sql.SQLIntegrityConstraintViolationException. MySQLIntegrityConstraintViolationException was needed because of c/J 5.1 hybrid code, it does nothing specific just extends this java.sql.SQLIntegrityConstraintViolationException.

换句话说,该包已被删除以重用现有的 java.sql 异常类,这是一件好事,但仍应记录在案。作为上述讨论的结果,已创建错误报告:Bug #91439 upgrade guide needs to inform of removed/refactored exceptions

当我进一步检查项目中的错误时,我发现了这 3 个异常及其 java.sql 映射:

  • com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException ->java.sql.SQLSyntaxErrorException
  • com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException-> java.sql.SQLIntegrityConstraintViolationException
  • com.mysql.jdbc.exceptions.jdbc4.MySQLTransactionRollbackException-> java.sql.SQLTransactionRollbackException

(我猜 jdbc4 包中的任何其他特定于 MySQL 的异常也映射到 java.sql 包中的类似 SQL 异常)

关于java - 包 com.mysql.jdbc.exceptions.jdbc4 在 Mysql Connector/J 8 中不存在,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51381118/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com