JDBC 的三种用法,推荐一种简单的用法【通用】

JDBC thin的三种连接格式:
jdbc:oracle:thin:@//<host>:<port>/<service_name>  
注意:@后有  //,这是与 使用SID的主要区别。
格式是Oracle 推荐的格式,因为对于集群来说,每个节点的SID 是不一样的,但是SERVICE_NAME 确可以包含所有节点

jdbc:oracle:thin:@ip:端口:实例名    [实例名是database的instance_name]

jdbc:oracle:thin:@<TNS_ALIAS_NAME>
TNS_ALIAS_NAME  的实现可以在oracle软件(完整的DB软件或客户端)中用tnsnames.ora参数文件来配置,也可用如下 格式:
jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL= TCP)(HOST=hostA)(PORT= 1522))(ADDRESS=(PROTOCOL=TCP)(HOST=your host)(PORT=1521)))(LOAD_BALANCE = yes)(CONNECT_DATA= (SERVER = DEDICATED)(SERVICE_NAME=your service_name)))

 

 

强烈推荐使用第1种,不要用第二种!

第3种也可以,对使用者有一定知识要求。

 

thin的第三种格式实现TNS_ALIA_NAME

用tnsnames.ora的示例:

String dbUrl = "jdbc:oracle:thin:@dvd";

 

报错如下:

java.sql.SQLException: Unknown host specified

该问题是因为JVM 没有oracle.net.tns_admin的system property。

解决方法有2种:

方法一:在启动VM 时添加如下参数: 

-Doracle.net.tns_admin=D:\app\Administrator\product\11.2.0\dbhome_1\NETWORK\ADMIN

方法二:在java 代码里添加:

System.setProperty("oracle.net.tns_admin","D:\\app\\Administrator\\product\\11.2.0\\dbhome_1\\NETWORK\\ADMIN");

方法三:设置环境变量TNS_ADMIN  ,地址为方法一后面等号值。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值