java.lang.UnsatisfiedLinkError:java中没有ocijdbc11。 library.path
我正在尝试与使用os身份validation的 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。
当试图在osvalidation到oracle数据库的客户机上运行上面的代码时,我得到以下exception:
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.(PhysicalConnection.java: 508) at oracle.jdbc.driver.T2CConnection.(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)
请告知我如何解决此exception。
如果您使用OCI URL( "jdbc:oracle:oci:/@"+tnsName
),那么您需要在类路径上使用oracle客户端库。 所以你需要在机器上安装oracle客户端。
但是,如果您使用瘦驱动程序并将URL指定为以下内容,则不需要oracle客户端。
"jdbc:oracle:thin:@"+dbServer+":"+port+":"+SID;
我能够在这篇文章中使用jdbc成功连接到oracle数据库:
如何使用os身份validation连接到oracle数据库?
尝试在/ usr/share/tomcat/conf/tomcat.conf
为ld_path设置正确的值:
LD_LIBRARY_PATH="/usr/lib/oracle/11.2/client64/lib:/usr/lib64"
如果你正在使用Eclipse和Jboss 6.1.0干扰。它将在线程“main”中显示错误exceptionjava.lang.UnsatisfiedLinkError:java中没有ocijdbc11。 library.path解决方案:从oracle \ product \ 11.2.0 \ client_1 \ BIN复制ocijdbc11.dll并粘贴到
d:\ jboss-6.1.0.Final \ BIN \本地
我认为您遇到此问题是因为您使用的是JRE 1.6或更低版本的Java与type-2驱动程序。 请用JRE 1.7或JRE 1.8替换JRE 1.6 buildpath。 它将解决问题。
请按照以下步骤操作:
- 右键单击项目文件夹
- 单击“属性”
- 单击java构建路径。
- 从库中选择jre 1.6或以下的“jre系统库”并将其删除,因为这会成为原因的来源。
- 现在单击添加库
- 单击jre系统库
- 点击下一步
- 通过单击环境按钮选择执行环境为JavaSE-1.8(jre1.8.0_144),然后按确定。
- 单击已安装的jre按钮
- 从中选择jre1.8(如果jre1.8不存在则点击添加按钮并添加它)。
- 单击完成。
- 点击确定。
- valah! 你会发现你的代码在运行。