建立dblink(database link)
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) 编辑 收藏 举报