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 ,地址为方法一后面等号值。