0

我在这里看到了很多类似的问题,但我找不到我的案例。

我写了一个演示程序来检查 JDBC。这是它的开头:

import java.sql.*;
import oracle.jdbc.*;
import oracle.jdbc.OracleConnection;
import java.io.*;

class JdbcCheckup {
    public static void main(String args[])
    throws SQLException, IOException, ClassNotFoundException {
        Class.forName("oracle.jdbc.OracleDriver");
        OracleConnection conn = null;
        conn = (OracleConnection) DriverManager.getConnection("jdbc:oracle:oci8:usr/pass@ldap:host");
        // ...

然后我运行以下命令并得到ClassNotFoundException

$ /usr/java71_64/bin/javac -cp /oracle/client/o12r1/jdbc/lib/ojdbc7.jar demo.java
$ /usr/java71_64/bin/jar -cvfm demo.jar MANIFEST.MF JdbcCheckup.class
added manifest
adding: JdbcCheckup.class(in = 2345) (out = 1356)(deflated 42%)
$ /usr/java71_64/bin/java -cp /oracle/client/o12r1/jdbc/lib/ojdbc7.jar:/oracle/client/o12r1/jlib/orai18n.jar -Djava.library.path=$ORACLE_HOME/lib -jar demo.jar
java.lang.ClassNotFoundException: oracle.jdbc.OracleDriver
        at java.lang.Class.forNameImpl(Native Method)
        at java.lang.Class.forName(Class.java:199)
        at JdbcCheckup.main(demo.java:27)

ojdbc7.jar我可以看到的oracle.jdbc.OracleDriver类中:

$ /usr/java71_64/bin/jar -tf /oracle/client/o12r1/jdbc/lib/ojdbc7.jar | grep Driver
META-INF/services/java.sql.Driver
oracle/jdbc/OracleDriver.class
oracle/jdbc/driver/OracleDriver$1.class
oracle/jdbc/driver/OracleDriver.class
oracle/jdbc/driver/OracleDriverExtension.class
oracle/jdbc/driver/T2CDriverExtension.class
oracle/jdbc/driver/T4CDriverExtension.class

所以请解释我做错了什么?

4

1 回答 1

0

非常感谢!

按照评论中的建议,我Class-Path在清单文件中添加了。

$ cat MANIFEST.MF
Main-Class: JdbcCheckup
Class-Path: /oracle/client/o12r1/jdbc/lib/ojdbc7.jar /oracle/client/o12r1/jlib/orai18n.jar

$ /usr/java71_64/bin/javac -cp /oracle/client/o12r1/jdbc/lib/ojdbc7.jar demo.java
$ /usr/java71_64/bin/jar -cvfm demo.jar MANIFEST.MF JdbcCheckup.class
added manifest
adding: JdbcCheckup.class(in = 2345) (out = 1356)(deflated 42%)
$ /usr/java71_64/bin/java -Djava.library.path=$ORACLE_HOME/lib -jar demo.jar
于 2017-07-24T12:05:49.220 回答