oracle database link,它是用来更方便的一个数据库中访问另一个数据库(包括本地和远程的,道理一样)在本地建立的。即数据库连接只是连到别的数据库的快捷方式。
例如在192.168.104.191上有个nsbd数据库,用户名和密码分别是aqjc、aqjc,LISTENER 端口号是1522
在192.168.104.178上有个orcl数据库,用户名和密码分别是aqjc、aqjc, LISTENER端口号是1521,数据库有张表名为static_pointformula,表中字段有spointformulaguid和spointguid
1.创建database link
先在191机器上创建database link,创建语句有两种方式:
第一种,先在tnsnames.ora里配置连接178的字符串,如下所示
178 =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.104.178)(PORT = 1521))
)
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
)
)
然后用sql 语句创建database link,创建语句如下所示:
Create public database link dblinkName connect to username
identified by password using ‘connect string’
其中dblinkName为创建database link的名称,username和password分别为连接字符串’connect string ‘所指向的服务器中的数据库的用户名和密码,所以创建连接178机器上的database link如下所示:
Create public database link aaa connect to aqjc identified by aqjc using ‘178’
第二种,不用在tnsnames.ora里配置连接178的字符串,可以直接写在创建database link语句里,如下所示:
Create public database link aaa connect to aqjc identified by aqjc using ‘(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.104.178)(PORT = 1521))
)
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
)’
2. 使用database link
public class TestDatabaseLink {
static Connection conn = null;
static {
try {
Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
String user = "aqjc";
String password = "aqjc";
String url = "jdbc:oracle:thin:@localhost:1522:nsbd";
conn = DriverManager.getConnection(url,user,password);
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
try {
//增、删、改、查语句如下所示,其中每个语句的表名static_pointformula后面跟的aaa是前面创建的database link的名称
conn.setAutoCommit(false);
Statement stat = conn.createStatement();
String sqlString = "insert into static_pointformula@aaa (spointformulaguid,spointguid) values('1','S_145')";
//sqlString = "update static_pointformula@aaa set norderid = '1' where spointformulaguid = '1'";
//sqlString = "delete from static_pointformula@aaa where spointformulaguid = '1'";
//System.out.println(stat.executeUpdate(sqlString));
conn.commit();
ResultSet rs = stat.executeQuery("select * from static_pointformula@dblinkName");
while(rs.next()){
System.out.println(rs.getString(1) + "\t" + rs.getString(2) + "\t" + rs.getString(3));
}
} catch (SQLException e) {
try {
conn.rollback();
} catch (SQLException e1) {
e1.printStackTrace();
}
e.printStackTrace();
}
}
}
分享到:
相关推荐
关于 database links 和 synonym 的一点知识
Oracle数据库链Database links
SQLite-Database 使用案例 个人也是安卓初学者,认为这个案例比较好,提供给初学者看看
1.1 Oracle Pluggable Database 6 1.1.1 可插拔数据库概述 6 1.1.2 Multitenant 多租户功能改进 7 1.1.3 Pluggable database适应场景 7 1.1.4 Pluggable Database 带来的好处 8 1.1.5 通过DBCA创建12c可插拔数据库...
Oracle数据库如何创建DATABASE LINK
数据库工具Database4,各种数据库连接方便; 数据库工具Database4,各种数据库连接方便; 数据库工具Database4,各种数据库连接方便; 数据库工具Database4,各种数据库连接方便; 数据库工具Database4,各种数据库连接...
对Oracle数据库12c的一些新特性总结,包括数据库管理、RMAN、高可用性以及性能调优等内容!
database systems and database applications. Our presentation stresses the funda- mentals of database modeling and design, the languages and models provided by the database management systems, and ...
今天刚做的ibatis入门小案例,适合初学者学习使用.我使用的是oracle,如果下载是使用的oracle的DataBase只需要创建一个学生表就OK了,如果是其他数据库还需要修改SqlMap.properties的数据库的连接语句.
The Database Comparer VCL represents 100% Delphi VCL components for Borland Delphi / C++Builder. These components allow you to compare and synchronize SQL database objects and table records for many ...
Oracle Database 21c 是最新的版本; 21.3 - 企业版(也包括标准版 2) 适用于Linux x86-64位系统。oracle-database-ee-21c-1.0-1.ol8文件分割成 三个 压缩包,必须集齐 三个 文件后才能一起解压一起使用: Oracle ...
Six-Step Relational Database DesignTM bridges the gaps between database theory, database modeling, and database implementation by outlining a simple but reliable six-step process for accurately ...
Oracle Database 12c 适用于Windows 64位系统, winx64_12102_database文件分割成 三个 压缩包,必须集齐 三个 文件后才能一起解压一起使用: Oracle Database 12c (winx64_12102_database.part3.rar) ...
vb database vb database vb database vb database
Oracle Database 12c 适用于Windows 64位系统, winx64_12102_database文件分割成 三个 压缩包,必须集齐 三个 文件后才能一起解压一起使用: Oracle Database 12c (winx64_12102_database.part3.rar) ...
很实用的总结,希望能够帮到有需要的各位
为了在SQLite上运行这个案例,对SQL语句进行一些调整以确保它们与SQLite的语法兼容。 运行:sqlite3 your_database_name.db < database_schema.sql 打开数据库:sqlite3 your_database_name.db 显示表结构:.schema
AXPPacker+DataBaseEditor
Oracle Database 19c 是最新的长期版本,支持期限最长; 19.3 - 企业版(也包括标准版 2) 适用于Linux x86-64系统。oracle-database-ee-19c文件分割成 三个 压缩包,必须集齐 三个 文件后才能一起解压一起使用: ...