【发布时间】:2013-10-13 22:37:09
【问题描述】:
我正在尝试将 jdbc oci 连接 连接到使用 os 身份验证
的 oracle 11g我制作了一个示例控制台应用程序来测试某些客户端机器上的连接
我在具有 jdk 6 的机器上开发了应用程序,并在项目中使用了 jar ojdbc6.jar。
我用来连接数据库的代码如下:
OracleDataSource ods = new OracleDataSource();
String tnsName="Prod";
ods.setURL("jdbc:oracle:oci:/@"+tnsName);
Connection conn = ods.getConnection();
我正在尝试从安装了 oracle11g 的客户端计算机上运行此应用程序,并且 oracle home 的路径设置为:C:\orant\jdk\bin
还有路径:C:\orant\bin包含oci.dll且不包含ocijdbc11.dll
客户端安装了jre7,没有jdk。
当试图在经过操作系统认证到 oracle 数据库的客户端机器上运行上述代码时,我收到以下异常:
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)
请告知我该如何解决此异常。
【问题讨论】:
-
您应该将
ocijdbc.dll作为 Oracle 安装的一部分;我不确定它在 Windows 中的位置,但在 Linux 中它位于ORACLE_HOME/lib下。我认为,您也需要PATH中的任何目录。我没有环境可以检查,所以我不太确定。或者this 可能会起作用... -
可能是 32 位 64 位问题。该dll和您的Java的位数是多少? BTW:
ocijdbc11是符号名,不一定与文件名匹配。 -
@Alex Poole,@Mark Rotteveel 我在客户端机器上找不到 ocijdbc11.dll 吗?请建议尝试的解决方案。
-
@Alex Poole,@Mark Rotteveel 我认为还有其他方法可以在不需要 dll 的情况下建立连接,对吧?
标签: java oracle jdbc oracle-call-interface