Oracle建立DB-LINK


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)

   )

  )

相关内容

    暂无相关文章