Oracle开发jdbc thin与 oci 连接方式 区别

一、jdbc thin

1.1 定义

thin就是纯粹用Java写的ORACLE数据库访问接口

瘦客户端的连接方式,采用这种连接方式不需要安装oracle客户端,只要求包含jdbc驱动的jar包就行。

1.2 实现

参考: JDBC连接Oracle数据库(一)-CSDN博客

ini 复制代码
import java.sql.Connection;
import java.sql.DriverManager;

public class Main {

	public static void main(String[] args) {
		  Connection conn=null;
		  
		  try {
			String url="jdbc:oracle:thin:@127.0.0.1:1521:orcl";
			  String user="hr";
			  String password="xyy123";
			  
			  Class.forName("oracle.jdbc.driver.OracleDriver");//加载数据驱动
			  conn = DriverManager.getConnection(url, user, password);// 连接数据库
			  
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
			System.out.println("加载数据库驱动失败");
		}catch(Exception e){
			e.printStackTrace();
			System.out.println("连接数据库失败");
		}

	}

}

二、jdbc oci

2.1 定义

oci是一种胖客户端的连接方式,采用这种连接方式需要安装oracle客户端。

oci是Oracle Call Interface的首字母缩写,是ORACLE公司提供了访问接口。

使用Java来调用本机的Oracle客户端,然后再访问数据库,优点是速度 快,但是需要安装和配置数据库。

2.2 实现

参考: java使用oci方式连接oracle_ocijdbc23 csdn-CSDN博客

ini 复制代码
import java.sql.Connection;
import java.sql.DriverManager;

public class Main {

	public static void main(String[] args) {
		  Connection conn=null;
		  
		  try {
			String url="jdbc:oracle:oci:@127.0.0.1:1521:orcl";
			  String user="hr";
			  String password="xyy123";
			  
			  Class.forName("oracle.jdbc.driver.OracleDriver");//加载数据驱动
			  conn = DriverManager.getConnection(url, user, password);// 连接数据库
			  
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
			System.out.println("加载数据库驱动失败");
		}catch(Exception e){
			e.printStackTrace();
			System.out.println("连接数据库失败");
		}

	}

}

三、区别

oci必须在客户机上安装oracle客户端或才能连接,而thin就不需要,因此从使用上来讲thin还是更加方便,这也是thin比较常见的原因。

thin是纯java实现tcp/ip的c/s通讯;而oci方式,

thin驱动切换到oci驱动很简单,只需把连接字符串java:oracle:thin:@hostip:1521:实例名换为java:oracle:oci@本地服务名即可。

相关推荐
追逐时光者2 小时前
精选 4 款基于 .NET 开源、功能强大的 Windows 系统优化工具
后端·.net
TF男孩2 小时前
ARQ:一款低成本的消息队列,实现每秒万级吞吐
后端·python·消息队列
AAA修煤气灶刘哥4 小时前
别让Redis「歪脖子」!一次搞定数据倾斜与请求倾斜的捉妖记
redis·分布式·后端
AAA修煤气灶刘哥4 小时前
后端人速藏!数据库PD建模避坑指南
数据库·后端·mysql
你的人类朋友4 小时前
什么是API签名?
前端·后端·安全
昵称为空C6 小时前
SpringBoot3 http接口调用新方式RestClient + @HttpExchange像使用Feign一样调用
spring boot·后端
架构师沉默7 小时前
设计多租户 SaaS 系统,如何做到数据隔离 & 资源配额?
java·后端·架构
RoyLin7 小时前
TypeScript设计模式:适配器模式
前端·后端·node.js
该用户已不存在7 小时前
Mojo vs Python vs Rust: 2025年搞AI,该学哪个?
后端·python·rust
Moonbit7 小时前
MoonBit 正式加入 WebAssembly Component Model 官方文档 !
前端·后端·编程语言