承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

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

管理员 2023-07-06 08:04:55 互联网圈 5 ℃ 0 评论 2855字 收藏

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⑴2514,在上面的代码中为了方便浏览其中进行了换行,可能会出现空格而致使毛病,所以使用的时候将空格去掉就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数据库程序设计有所帮助。

文章来源:丸子建站

文章标题:oracle跨库查询dblink的用法实例详解

https://www.wanzijz.com/view/61982.html

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信