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@本地服务名即可。

相关推荐
星哥的编程之路3 分钟前
别再调 API 就说自己会 RAG 了,看看真正的企业级 AI 智能体长什么样
后端·面试
长大19885 分钟前
C++26 静态反射完整实战:告别宏代码生成,一键实现序列化
后端
yb7797 分钟前
Java 21 虚拟线程最佳实践:虚拟线程如何让高并发 Java 服务更轻更快
后端
fliter10 分钟前
绕过系统 ICMP:用 rawsock、Npcap 和 WMI 找到默认网卡
后端
AHRIKNOW11 分钟前
AFaster:一个开箱即用的 Rust 高性能后端框架模板
后端
小强198812 分钟前
C++20 协程从入门到网络服务
后端
鱼人12 分钟前
C++ 内存模型详解:原子操作、内存屏障
后端
二月龙13 分钟前
RAII 与智能指针深度拆解
后端
极速蜗牛14 分钟前
我在 Taro 小程序项目里实践的 API First + AI 编程方式
前端·人工智能·后端
锋行天下1 小时前
数据库安全并发控制详解:乐观锁 vs 悲观锁 vs 原子操作
前端·数据库·后端