博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JDBC连接ORACLE的三种URL格式
阅读量:6094 次
发布时间:2019-06-20

本文共 4118 字,大约阅读时间需要 13 分钟。

使用jdbc连接oracle时url有三种格式

格式一: Oracle JDBC Thin using an SID:

jdbc:oracle:thin:@host:port:SID
Example: jdbc:oracle:thin:@localhost:1521:orcl
这种格式是最简单也是用得最多的
你的oracle的sid可以通过一下指令获得:
sqlplus / as sysdba
select value from v$parameter where name=’instance_name’;

import java.sql.*;

public class TestOrclConnect {

public static void main(String[] args) {    ResultSet rs = null;    Statement stmt = null;    Connection conn = null;    try {        Class.forName("oracle.jdbc.driver.OracleDriver");        String dbURL = "jdbc:oracle:thin:@localhost:1521:orcl";        conn = DriverManager.getConnection(dbURL, "admin2", "123");        System.out.println("连接成功");    } catch (ClassNotFoundException e) {        e.printStackTrace();    } catch (SQLException e) {        e.printStackTrace();    } finally {        try {            if (rs != null) {                rs.close();                rs = null;            }            if (stmt != null) {                stmt.close();                stmt = null;            }            if (conn != null) {                conn.close();                conn = null;            }        } catch (SQLException e) {            e.printStackTrace();        }    }}

}

阿里云代金券1000元免费领取地址:

新老阿里云账户均可领取!可用于购买阿里云服务器ECS、云数据库RDS、虚拟主机、安骑士、DDoS高防IP等100多云计算产品。 代金券自领取之日起,有效期是30天,请及时使用,过30天后还可以重新领取。

格式二: Oracle JDBC Thin using a ServiceName:

jdbc:oracle:thin:@//host:port/service_name
Example:jdbc:oracle:thin:@//localhost:1521/orcl.city.com
注意这里的格式,@后面有//, port后面:换成了/,这种格式是Oracle 推荐的格式,因为对于集群来说,每个节点的SID 是不一样的,但是SERVICE_NAME 确可以包含所有节点。
你的oracle的service_name可以通过以下方式获得:
sqlplus / as sysdba
select value from v$parameter where name=’service_names’;

import java.sql.*;

public class TestOrclConnect {

public static void main(String[] args) {    ResultSet rs = null;    Statement stmt = null;    Connection conn = null;    try {        Class.forName("oracle.jdbc.driver.OracleDriver");        String dbURL = "jdbc:oracle:thin:@//localhost:1521/orcl.city.com";        conn = DriverManager.getConnection(dbURL, "admin2", "123");        System.out.println("连接成功");    } catch (ClassNotFoundException e) {        e.printStackTrace();    } catch (SQLException e) {        e.printStackTrace();    } finally {        try {            if (rs != null) {                rs.close();                rs = null;            }            if (stmt != null) {                stmt.close();                stmt = null;            }            if (conn != null) {                conn.close();                conn = null;            }        } catch (SQLException e) {            e.printStackTrace();        }    }}

}

格式三:Oracle JDBC Thin using a TNSName:

jdbc:oracle:thin:@TNSName
Example: jdbc:oracle:thin:@TNS_ALIAS_NAME
我在谷歌上找了一些资源,要实现这种连接方式首先要建立tnsnames.ora文件,然后通过System.setProperty指明这个文件路径。再通过上面URL中的@符号指定文件中的要使用到的资源。
这种格式我现在水平几乎没见过,对于我来说用得到这种的情况并不多吧。当然既然是通过配置文件来读取指定资源肯定也可以直接将资源拿出来放在URL中,直接放在URL中的URL模版是下面这样的(tnsnames.ora这个文件中放的就是@符号后面的那一段代码,当然用文件的好处就是可以配置多个,便于管理):

jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL= TCP)(HOST=hostA)(PORT= 1522))(ADDRESS=(PROTOCOL=TCP)(HOST=your host)(PORT=1521)))(SOURCE_ROUTE=yes)(CONNECT_DATA=(SERVICE_NAME=your service_name)))

1
jdbc连接代码如下:

“`

import java.sql.*;

public class TestOrclConnect {

public static void main(String[] args) {

ResultSet rs = null;Statement stmt = null;Connection conn = null;try {    Class.forName("oracle.jdbc.driver.OracleDriver");     String dbURL =    "jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=localhost)(PORT=1521)))"    + "(CONNECT_DATA=(SERVICE_NAME=orcl.city.com)))";    conn = DriverManager.getConnection(dbURL, "admin2", "123");    System.out.println("连接成功");} catch (ClassNotFoundException e) {    e.printStackTrace();} catch (SQLException e) {    e.printStackTrace();} finally {    try {        if (rs != null) {            rs.close();            rs = null;        }        if (stmt != null) {            stmt.close();            stmt = null;        }        if (conn != null) {            conn.close();            conn = null;        }    } catch (SQLException e) {        e.printStackTrace();    }}

}

转载地址:http://stwza.baihongyu.com/

你可能感兴趣的文章
【设计模式系列】单例模式的7种写法
查看>>
汉字转拼音 (转)
查看>>
Machine Learning Techniques -6-Support Vector Regression
查看>>
会计基础_001
查看>>
Cordova 开发环境搭建及创建第一个app
查看>>
ajax请求拿到多条数据拼接显示在页面中
查看>>
小程序: 查看正在写的页面
查看>>
dedecms生成文档数据库崩溃 mysql daemon failed to start
查看>>
Linux的50个基本命令
查看>>
Objective-C中创建单例方法的步骤
查看>>
[转]无法安装MVC3,一直卡在vs10-kb2483190
查看>>
Codeforces 520B:Two Buttons(思维,好题)
查看>>
web框架-(二)Django基础
查看>>
Jenkins持续集成环境部署
查看>>
emoji等表情符号存mysql的方法
查看>>
Excel到R中的日期转换
查看>>
检查磁盘利用率并且定期发送告警邮件
查看>>
MWeb 1.4 新功能介绍二:静态博客功能增强
查看>>
linux文本模式和文本替换功能
查看>>
Windows SFTP 的安装
查看>>