栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 数据库 > Oracle

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

Oracle 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

oracle跨库查询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数据库程序设计有所帮助。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/171673.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号