繁体   English   中英

请让我知道与jdk 1.7兼容的任何MySQL版本

[英]Please let me know any MySQL version which works with jdk 1.7

我安装了JDK 1.7,并尝试连接到不同的MySQL数据库和Connector / J版本。 但是每次加载驱动程序时,都会出现以下错误:

Exception in thread "main" java.lang.ExceptionInInitializerError
 at java.lang.Class.forName0(Native Method)
 at java.lang.Class.forName(Class.java:186)
 at jdbc.JDBC.main(JDBC.java:24)
Caused by: java.lang.RuntimeException: Uncompilable source code - com.mysql.jdbc.NonRegisteringDriver is not abstract and does not override abstract method getParentLogger() in java.sql.Driver
 at com.mysql.jdbc.NonRegisteringDriver.<clinit>(NonRegisteringDriver.java:69)
 ... 3 more

哪个MySQL驱动程序版本与JDK 1.7兼容?

异常消息说明:

“由以下原因引起:java.lang.RuntimeException: 无法编译的源代码 -com.mysql.jdbc.NonRegisteringDriver不是抽象的,并且不会覆盖java.sql.Driver中的抽象方法getParentLogger()”

我认为问题在于您(或其他人)已经尝试从源代码构建JDBC驱动程序,而没有注意到存在编译错误,并将产生的损坏的“ .class”文件组装到JAR文件中。


MySQL网站上的标准Connector / J驱动程序JAR文件应与Java 7配合使用。当然,我从未遇到过类似的问题。


我更倾向于相信我可以在“异常”消息中看到的证据,而不是您对一切都“完美”的保证:

  • 您确定使用从MySQL网站下载的Connector / J JAR文件吗?

  • 您是否检查了MD5校验和以确保您得到了真实的东西?

  • 如果是从源代码构建的,您是否阅读了docs / readme.txt中有关正确构建所需JRE版本的内容?

  • 您的应用程序的类路径上是否有其他(损坏的)驱动程序副本?

"Caused by: java.lang.RuntimeException: Uncompilable source code -
com.mysql.jdbc.NonRegisteringDriver is not abstract and does not override
abstract method getParentLogger() in java.sql.Driver"

方法getParentLogger()被引入Java 1.7的Driver接口中。

发现,支持Java 1.7或切换回Java 1.6 MySQL驱动程序。

编辑:附加信息:

我测试了JDK 1.7.10和驱动jar命名为: mysql-connector-java-5.1.6-bin.jar

使用以下代码:

public static void main(String[] args) throws ClassNotFoundException,
        InstantiationException, IllegalAccessException, SQLException {
    System.out.println("Java version: "
            + System.getProperty("java.version"));
    Driver driver = (Driver) Class.forName("com.mysql.jdbc.Driver")
            .newInstance();
    System.out.println("JDBC driver: " + driver.getMajorVersion() + "."
            + driver.getMinorVersion());
    Connection connection = DriverManager.getConnection(
            "jdbc:mysql://localhost:3306/DBNAME", "user", "pass");
    System.out.println("Connection: " + connection.getClass().getName());
}

它给出以下输出:

Java version: 1.7.0_10
JDBC driver: 5.1
Connection: com.mysql.jdbc.JDBC4Connection

可能您的JDK / JRE安装也有问题。 安装JDK时,它想更新SQL驱动程序。
你可以给它一个尝试卸载并重新安装JDK。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM