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

oracle跨库查询dblink的用法实例详解

程序员文章站 2022-07-01 19:03:36
本文实例讲述了oracle跨库查询dblink的用法。分享给大家供大家参考,具体如下: 1.创建之前的工作 在创建dblink之前,首先要查看用户是否有相应的权限。针对...

本文实例讲述了oracle跨库查询dblink的用法。分享给大家供大家参考,具体如下:

1.创建之前的工作

在创建dblink之前,首先要查看用户是否有相应的权限。针对特定的用户,使用 sqlplus user/pwd登录后,执行如下语句:

复制代码 代码如下:
select * from user_sys_privs t where t.privilege like upper('%link%');

在sys用户下,显示结果为:

sys create database link no
sys drop public database link no
sys create public database link no

可以看出在数据库中dblink有三种权限:

create database link--所创建的dblink只能是创建者能使用,别的用户使用不了
create public database link--public表示所创建的dblink所有用户都可以使用
drop public database link--删除指定dblink

如果想要改变某个用户的权限,需要在sys用户下修改:

复制代码 代码如下:
grant create public database link,drop public database link to scott;

查看dblink,有两种方式,分别如下:

①.

复制代码 代码如下:
select owner,object_name from dba_objects where object_type='database link';

②.
复制代码 代码如下:
select * from dba_db_links;

2. 创建dblink

create public database link link_name
connect to usrname identified by "password"
using 
'(description =(address = (protocol = tcp)(host = xxx.xxx.xxx.xxx)(port = 1521))
(connect_data =(server = dedicated)(service_name = xxx))
 )';

注意:using后跟的是一个字符串,其中一定不要出现不必要的空格,否则会出错ora-12514,在上面的代码中为了方便阅读其中进行了换行,可能会出现空格而导致错误,所以使用的时候将空格去掉就ok了。

这里link_nam为自定的名称;username和password为指定的oracle数据库中的用户名和密码,service_name如果不确定的话,可以通过以下语句获得:

复制代码 代码如下:
show parameter service_names;

或者
复制代码 代码如下:
select name,value from v$parameter where name='service_names'

3.dblink的使用

dblink的使用相对比较简单,把一般访问本地表时的表名改为如下格式即可:[user.]table@link_name。

复制代码 代码如下:
select studentid from abc.studeng@abc_ten;

4.删除dblink

确定要删除的dblink名字以后,可以通过drop命令直接将其删除:

复制代码 代码如下:
drop public database link abc_ten;

希望本文所述对大家oracle数据库程序设计有所帮助。