龙空技术网

JDBC连接ORACLE的三种URL格式

爱音乐的程序员小新人 186

前言:

现时各位老铁们对“oracle的dbname和url”大概比较重视,朋友们都想要学习一些“oracle的dbname和url”的相关资讯。那么小编也在网摘上搜集了一些有关“oracle的dbname和url””的相关文章,希望小伙伴们能喜欢,同学们快快来学习一下吧!

使用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();

}

}

}

}

12345678910111213141516171819202122232425262728293031323334353637

格式二: 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();

}

}

}

}

12345678910111213141516171819202122232425262728293031323334353637

格式三: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();

}

}

}

1234567891011121314151617181920212223242526272829303132

33

标签: #oracle的dbname和url