内置.jar文件中的Derby数据库通信失败

时间:2018-01-08 10:24:56

标签: java jdbc derby

我创建了一个java应用程序,它使用以下代码连接到Derby Embedded Database:

Class.forName("org.apache.derby.jdbc.EmbeddedDriver").newInstance();
Connection con = DriverManager.getConnection("jdbc:derby:myDatabase;create=true");

使用Netbeans IDE并运行应用程序时,一切正常。但是当我构建项目并尝试通过.jar文件运行应用程序时,应用程序启动但无法访问Derby数据库。

我得到了以下StackTrace:

java.lang.ClassNotFoundException: org.apache.derby.jdbc.EmbeddedDriver
at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(Unknown Source)
    at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(Unknown Source)
    at java.base/java.lang.ClassLoader.loadClass(Unknown Source)
    at java.base/java.lang.Class.forName0(Native Method)
    at java.base/java.lang.Class.forName(Unknown Source)

但是当我构建项目时,我在pom.xml中包含以下依赖项:

<dependency>
    <groupId>org.apache.derby</groupId>
    <artifactId>derby</artifactId>
    <version>10.14.1.0</version>
  <type>jar</type>
</dependency>

1 个答案:

答案 0 :(得分:0)

我通过在pom.xml文件的构建中添加以下代码来解决问题:

<build>
  <plugins>
    <plugin>
    <artifactId>maven-dependency-plugin</artifactId>
    <executions>
        <execution>
            <phase>install</phase>
            <goals>
                <goal>copy-dependencies</goal>
            </goals>
            <configuration>
                <outputDirectory>${project.build.directory}/lib</outputDirectory>
            </configuration>
        </execution>
    </executions>
</plugin>
<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-jar-plugin</artifactId>
    <configuration>
        <archive>
            <manifest>
                <addClasspath>true</addClasspath>
                <classpathPrefix>lib/</classpathPrefix>
                <mainClass>MyMainClass</mainClass>
            </manifest>
        </archive>
    </configuration>
</plugin>
  </plugins>
</build>