5

OS認証を使用するOracle 11gへのjdbc oci接続を作成しようとしています

クライアントマシンで接続をテストするためのサンプルコンソールアプリケーションを作成しました

jdk 6を搭載したマシンでアプリケーションを開発し、プロジェクトでjar ojdbc6.jarを使用しました。

データベースへの接続に使用しているコードは次のとおりです。

OracleDataSource ods = new OracleDataSource();
String tnsName="Prod";
ods.setURL("jdbc:oracle:oci:/@"+tnsName);
Connection conn = ods.getConnection();

oracle11g がインストールされているクライアント マシンからこのアプリケーションを実行しようとしています。Oracle ホームは次のパスに設定されています: C:\orant\jdk\bin

また、パス: C:\orant\binにはoci.dllが含まれ、 ocijdbc11.dllは含まれません。

クライアントには jre7 がインストールされており、jdk はありません。

Oracleデータベースに対してos認証されたクライアントマシンで上記のコードを実行しようとすると、次の例外が発生します。

Exception in thread "main" java.lang.UnsatisfiedLinkError: no ocijdbc11 in java.
library.path
        at java.lang.ClassLoader.loadLibrary(Unknown Source)
        at java.lang.Runtime.loadLibrary0(Unknown Source)
        at java.lang.System.loadLibrary(Unknown Source)
        at oracle.jdbc.driver.T2CConnection$1.run(T2CConnection.java:3178)
        at java.security.AccessController.doPrivileged(Native Method)
        at oracle.jdbc.driver.T2CConnection.loadNativeLibrary(T2CConnection.java
:3174)
        at oracle.jdbc.driver.T2CConnection.logon(T2CConnection.java:233)
        at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:
508)
        at oracle.jdbc.driver.T2CConnection.<init>(T2CConnection.java:133)
        at oracle.jdbc.driver.T2CDriverExtension.getConnection(T2CDriverExtensio
n.java:53)
        at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:510)
        at oracle.jdbc.pool.OracleDataSource.getPhysicalConnection(OracleDataSou
rce.java:275)
        at oracle.jdbc.pool.OracleDataSource.getConnection(OracleDataSource.java
:206)
        at oracle.jdbc.pool.OracleDataSource.getConnection(OracleDataSource.java
:156)
        at auth.Main.main(Main.java:42)

この例外を修正する方法を教えてください。

4

5 に答える 5

0

この投稿では、jdbc を使用して Oracle データベースへの OS 接続を成功させることができました。

OS認証でOracleデータベースに接続するには?

于 2013-10-09T07:14:50.640 に答える
0

Jboss 6.1.0 障害で Eclipse を使用している場合、エラー Exception in thread "main" java.lang.UnsatisfiedLinkError: no ocijdbc11 in java が表示されます。library.path 解決策: ocijdbc11.dll を oracle\product\11.2.0\client_1\BIN からコピーして貼り付けます

D:\jboss-6.1.0.Final\bin\native

于 2016-02-03T06:04:53.560 に答える