欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

Oracle建立DB-LINK

程序员文章站 2024-01-27 16:31:58
...

Oracle建立DB-LINK 测试条件 两台服务器 远程:IP:192.168.0.18,SID: usertest,用户名:usertest,密码:123456 本地:IP: 192.168.8.

Oracle建立DB-LINK

测试条件

两台服务器

远程:IP:192.168.0.18,SID: usertest,用户名:usertest,密码:123456

本地:IP: 192.168.8.90,SID: wjn,用户名:userwjn,密码:mosquito0

参数设置

1. 查看数据库global_name

执行select * from global_name;

远程数据库18返回: USERTEST.US.ORACLE.COM

本地数据库90返回: DB_WJN.REGRESS.RDBMS.DEV.US.ORACLE.COM

2. 查看global_name参数

SQL>show parameterglobal_name;

NAME TYPE VALUE

----------------------------------------------- ------------------------------

global_names boolean FALSE

该参数为TRUE时,本地连接的DBLINK的名称必须和远程的global_name一致.

3. 查看是否支持高级复制功能

查看v$option视图, Advanced replication为true则支持,否则不支持

select * from v$option t wheret.PARAMETER like 'Advanced replication%';

建立方法

1.创建dblink的第一种方式,是在本地数据库tnsnames.ora文件中配置了要远程访问的数据库。

create database link USERTEST_18connect to USERTEST identified by xxxx using 'USERTEST_192.168.0.18';

  其中USERTEST_18是你创建的dblink名字,usertest是远程数据库的实例名,,USERTEST/xxxx是登录到远程数据库的用户/密码。然后在本地数据库中通过dblink访问远程数据库18中dual表,sql语句如下所示

  select * from dual@ USERTEST_18;

2.创建dblink的第二种方式,是在本地数据库tnsnames.ora文件中没有配置要访问的远程数据库

create public database link USERTEST_18

connect to USERTEST

identified by 123456 using

'(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.18)(PORT = 1521))

)

(CONNECT_DATA =

(SID = usertest)

(SERVER = DEDICATED)

)

)';

  第二种是把第一种配置在tnsnames.ora文件中的信息,直接放在创建dblink语句后面。第一种情况tnsnames.ora文件中信息如下:

USERTEST_192.168.0.18 =

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.18)(PORT = 1521))

)

(CONNECT_DATA =

(SID = usertest)

(SERVER = DEDICATED)

)

)

Oracle建立DB-LINK