【问题标题】:Derby gives ClassNotFoundException: org.apache.derby.jdbc.EmbeddedDriver while using MavenDerby 在使用 Maven 时给出 ClassNotFoundException: org.apache.derby.jdbc.EmbeddedDriver
【发布时间】:2017-01-09 05:51:16
【问题描述】:

我看到了以下主题,但他们没有发布我的问题的解决方案:

  1. java.lang.ClassNotFoundException: org.apache.derby.jdbc.EmbeddedDriver
  2. JDBC Derby driver not found
  3. SQLException: No suitable driver found for jdbc:derby://localhost:1527
  4. Class [org.apache.derby.jdbc.ClientDriver] not found Exception
  5. Class [org.apache.derby.jdbc.ClientDriver] not found. When trying to connect to db
  6. ClassNotFoundException: org.apache.derby.jdbc.EmbeddedDriver when trying to use JPA with Derby

你好。
在我的项目中,我使用的是 Maven,并且我还想在嵌入式模式下使用 Derby 数据库。因此,我通过以下方式更新了 pom.xml 文件:

<dependencies>
    ...
    <dependency>
        <groupId>org.apache.derby</groupId>
        <artifactId>derby</artifactId>
        <version>10.12.1.1</version>
    </dependency>
</dependencies>

Maven 成功下载了依赖。它在 Maven Dependencies 下的 Eclipse BuildPath 中显示为 derby-10.12.1.1.jar
然后我创建了测试类:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import org.apache.derby.jdbc.EmbeddedDriver;

public class DerbyTest {
    public static void main (String...strings){
         try {
             DriverManager.registerDriver(new EmbeddedDriver());
            Connection conn = DriverManager.getConnection("jdbc:derby:test2;create=true");
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}

这给了我关注 ClassNotFoundException

Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/derby/jdbc/EmbeddedDriver
    at DerbyTest.main(DerbyTest.java:10)
Caused by: java.lang.ClassNotFoundException: org.apache.derby.jdbc.EmbeddedDriver
    at java.net.URLClassLoader.findClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    ... 1 more

问题是 - 为什么? 该类位于构建路径中。 Eclipse 没有给我任何编译时错误警告——它在编写过程中看到了这个类。依赖的范围是编译。 JVM 不应该有查找类的问题。此外,JVM 对我正在使用的其他依赖项(jTest、Hibernate、SQLite)没有问题。

Post Scriptum:我试图解决这个难题:

  1. 我用与上面相同的测试类创建了新项目。然后我从https://db.apache.org/derby/releases/release-10.12.1.1.cgi(bin 版)手动下载了Derby,并手动将derby.jar 添加到了新项目的构建路径中。运行程序后,数据库已成功创建

  2. 然后我创建了另一个 新项目 2,其测试类与之前相同。我在我的本地存储库中找到了 Maven 的 Debry 版本(在 C:\Users\User\.m2\repository\org\apache\derby\derby\10.12.1.1 中)并手动添加了 derby-10.12.1.1.jar 到新项目的构建路径。运行程序后,我得到了与使用 Maven 完全相同的相同的错误

  3. 我使用手动下载的 Derby(从第 1 点开始)并通过在我的 主项目中编辑 pom.xml 文件创建了外部存储库强>:

.

<repositories>
    <repository>
        <id>derby-repo</id>
        <url>file://C:/libs</url>
    </repository>
</repositories>

<dependencies>
    ...
    <dependency>
        <groupId>derbygroupid</groupId>
        <artifactId>derby</artifactId>
        <version>0.0.1</version>
    </dependency>
</dependencies>

Maven 成功在 Maven Dependencies 下的 Eclipse 的 BuildPath 中添加了一个依赖项,即 derby-0.0.1.jar。运行程序后数据库已成功创建
这通常可以解决问题,但问题是,为什么 Maven 无法自行处理

编辑:对于那些感兴趣的人。我通过使用旧版本的 derby 暂时解决了问题:

<dependencies>
    ...
    <dependency>
        <groupId>org.apache.derby</groupId>
        <artifactId>derby</artifactId>
        <version>10.11.1.1</version>
    </dependency>
</dependencies> 

这个版本有效,但我仍然不知道为什么 10.12.1.1 没有

【问题讨论】:

  • 也许线索在术语BuildPath 中。也许BuildPath 仅在您构建 项目时使用,而不是在您运行 项目时使用?
  • 如何判断BuildPath是否只用于构建?另一方面,在同一个项目中,手动下载的 derby 可以工作,而 maven 的 derby 则不能。
  • 2021 仍然面临同样的问题,感谢您的回答。

标签: java maven derby noclassdeffounderror classnotfoundexception


【解决方案1】:

我也遇到了同样的问题,但我解决了...

由于我在从事intellij工作,所以我去了

文件->项目结构->模块->依赖项

单击加号并选择 JAR 和依赖项

打开 jdk 的路径,并在其中添加以下 jar 文件 1. derby.jar 2. derbyclient.jar 3. derbynet.jar 4. derbytools.jar 5. derby.jar

点击应用。成功了!

对于 Eclipse,请尝试 this

【讨论】:

    【解决方案2】:

    虽然我还不明白为什么会这样:从 Java 1.6 开始,即使您不手动注册驱动程序,您对 DriverManager.getConnection() 的调用也会成功。尝试省略创建 EmbeddedDriver 的实例来注册驱动程序并仅获取 Connection 对象。我在调用 Class.forName("org.apache.derby.jdbc.EmbeddedDriver") 时遇到了同样的异常,只是将其删除。

    但是,关闭 Derby 将注销驱动程序。因此,如果您打算重新启动 Derby,则此技巧将只工作一次,直到您关闭 Derby。在关机时传递“deregister=false”将确保在初始注册后不会删除 Derby Driver。

    我正在使用同一个 Maven 包的 10.15.2.0,并且我的 pom.xml 中没有更多的 derby 包。

    【讨论】:

      【解决方案3】:

      我遇到了同样的问题,通过恢复到 10.11.1.1 版本的驱动程序一切正常。

      【讨论】:

        猜你喜欢
        • 2010-12-26
        • 2021-06-26
        • 1970-01-01
        • 1970-01-01
        • 2019-12-27
        • 2020-04-07
        • 1970-01-01
        • 2020-08-19
        • 1970-01-01
        相关资源
        最近更新 更多