java - 加载 postgreSQL JDBC 驱动程序

标签 java postgresql jdbc

我正在尝试为 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。

我们将不胜感激。

最佳答案

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

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

java com.freire.test.JDBCExample

但它现在会因为找不到 postgres 驱动程序类而哭泣,因为类路径中缺少 postgres jar。因此您需要在运行程序时使用类路径选项并将您的 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

关于java - 加载 postgreSQL JDBC 驱动程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19216072/

相关文章:

java - 在 Java 中将类转换为字符串,反之亦然

java - 使用工厂方法使用 @JsonCreator 反序列化枚举

postgresql - 在 Postgres 中返回 json_build_object 处理删除语句中未找到的记录

java - Spring JDBC 数据驱动更新

java - JDBC 准备语句,编译器无法识别 set 方法

java - 使用 HQL 查询的 Hibernate 批量更新

java - 如何在JCombobox中每行显示不同的值

java - 如何在 Java 源文件中获取给定行号的周围方法

sql - 在 postgresql 中出现错误 "record type has not been registered"。怎么了?

xml - 如何使用 PostgreSQL 将一对多关系呈现给 XML