3

我正在尝试为 Java 程序加载 JDBC postgreSQL 驱动程序。我知道这在互联网上到处都是。我尝试了很多解决方案,但没有一个对我有用。

问题是我收到此错误:

Exception in thread "main" java.lang.NoClassDefFoundError:    
classes/com/freire/test/JDBCExample/class
Caused by: java.lang.ClassNotFoundException: classes.com.freire.test.JDBCExample.class
at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
at java.lang.ClassLoader.loadClass(ClassLoader.java:247)

我的代码如下所示:

package com.freire.test;
import java.sql.DriverManager;
import java.sql.Connection;
import java.sql.SQLException;

public class JDBCExample 
{
    public static void main(String[] argv) 
    {
        System.out.println("JDBC Connection Testing");
        try {
            Class.forName("org.postgresql.Driver");
        } catch (ClassNotFoundException e) {
            System.out.println("PostgreSQL JDBC Driver not included!");
        }
    }
}

我的项目结构如下:

myProject
 src
   com
     freire
       test
         JDBCExample.java
 classes
   com
     freire
       test
         JDBCExample.class
 lib
   postgresql-9.2-1003.jdbc3.jar

编译工作正常:

java -d classes/ src/com/freire/test/JDBCExample.java

但是执行会产生错误:

java classes/com/freire/test/JDBCExample

值得一提的是,我正在开发 OS X Mountain Lion。

任何帮助将不胜感激。

4

3 回答 3

4

首先,您需要在运行 java 程序时使用.而不是提及包名称:/

转到您的类目录并运行 JDBCExample 为:

java com.freire.test.JDBCExample

但是现在它会为找不到 postgres 驱动程序类而哭泣,因为类路径中缺少 postgres jar。因此,您需要在运行程序时使用 classpath 选项并将您的 postgres jar 添加到类路径中:

对于窗户:

java -cp .;../lib/postgresql-9.2-1003.jdbc3.jar com.freire.test.JDBCExample

对于 Linux:

java -cp .:../lib/postgresql-9.2-1003.jdbc3.jar com.freire.test.JDBCExample
于 2013-10-07T02:02:40.420 回答
1

在 Linux 上执行以下命令:

javac -cp '.:postgresql-9.1-901.jdbc4.jar' postgresjavatest.java

java -cp '.:postgresql-9.1-901.jdbc4.jar' postgresjavatest

它将为您提供 jdbc 驱动程序。确保 jar 文件位于同一位置

于 2014-01-29T09:58:19.430 回答
0

编译运行程序时需要确保postgresql-9.2-1003.jdbc3.jar在类路径内

尝试使用

javac -cp lib/postgresql-9.2-1003.jdbc3.jar -d classes/ src/com/freire/test/JDBCExample.java

编译应用程序和

java -cp lib/postgresql-9.2-1003.jdbc3.jar;./classes com.freire.test.JDBCExample

运行它...

nb正如 Juned 所指出的,从技术上讲,您不需要lib/postgresql-9.2-1003.jdbc3.jar类路径中的引用,但可以将其视为如何在复杂过程中包含编译时依赖项的演示;)

于 2013-10-07T02:05:00.077 回答