建立dblink(database link)

版权声明:本文为博主原创文章,未经博主同意不得转载。 https://blog.csdn.net/bisal/article/details/26730993

database linke是建立一个数据库到还有一个数据库的路径的对象,通过database link能够同意查询远程表。我理解能够算作一种分布式数据库的使用方法。


database link是单向连接。既然它是一种对象,那自然能够在xxx_objects表中查询到相关的信息。

建立database link前须要明白几个事情:

1、确认从建立方的server能够訪问远程数据库。

2、须要在建立方的tnsnames中配置远程数据库连接串。

3、仅仅有在服务端配置的连接才干在dblink中使用,假设仅是在client配置的连接是不能在dblink中使用。我这里就犯了这个错误,运行时就报错:

select * from t@dblinktest
                *
ERROR at line 1:
ORA-12154: TNS:could not resolve service name

非常明显。相当于服务端未配置tnsname,因此找不到远程数据库的service name配置。


建立过程:

1、建立方的服务端配置远程数据库的tnsname配置。

2、tnsping 远程数据库tnsnames配置名称。能够通。

3、sqlplus登录后运行:

SQL> create database link dblinktest connect to user identified by passwd using 'ceshi';

当中:

dblinktest是database link的名称。

user是远程数据库的username。

passwd是远程数据库的password。

ceshi是数据库服务端配置的tnsnames中名称。

4、运行:

SQL> select owner,object_name from dba_objects where object_type='DATABASE LINK';
OWNER           OBJECT_NAME
--------------- -------------------------
OPEN               DBLINKTEST

能够看到已经建立了这个database link。

5、运行:

SQL> select * from t@dblinktest;
        ID
----------
         0
         2
         3
         4
         5

当然也能够运行insert语句:

SQL> insert into t@dblinktest values(1);
1 row created.


另外database link分为public和private的,默认是private。仅仅有当前用户可用,假设是create public database link ...,则全部用户都能够使用这个名称的database link。

posted on 2019-04-04 18:26  xfgnongmin  阅读(230)  评论(0编辑  收藏  举报

导航