我正在尝试将 jdbc oci连接与 oracle 11g 一起使用 os身份验证
我制作了一个示例控制台应用程序来测试某个客户端计算机上的连接
我在 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)
请告知我如何解决此异常。
答案 0 :(得分:3)
如果您使用OCI网址("jdbc:oracle:oci:/@"+tnsName
),那么您需要在类路径上使用oracle客户端库。所以你需要在机器上安装oracle客户端。
但是如果您使用瘦驱动程序并将URL指定为以下内容,则不需要oracle客户端。
"jdbc:oracle:thin:@"+dbServer+":"+port+":"+SID;
答案 1 :(得分:0)
我能够在这篇文章中用jdbc成功地连接到oracle数据库:
答案 2 :(得分:0)
尝试在/ usr/share/tomcat/conf/tomcat.conf
中为ld_path设置正确的值:
LD_LIBRARY_PATH="/usr/lib/oracle/11.2/client64/lib:/usr/lib64"
答案 3 :(得分:0)
如果你正在使用Eclipse和Jboss 6.1.0干扰。它会显示错误 线程“main”中的异常java.lang.UnsatisfiedLinkError:java中没有ocijdbc11。 library.path 方案: 从oracle \ product \ 11.2.0 \ client_1 \ BIN复制ocijdbc11.dll并粘贴到
d:\ jboss-6.1.0.Final \ BIN \天然
答案 4 :(得分:0)
我认为您遇到此问题是因为您使用的是JRE 1.6或更低版本的Java与type-2驱动程序。请用JRE 1.7或JRE 1.8替换JRE 1.6 buildpath。它将解决问题。
请按照以下步骤操作: