时间:2021-05-24
本文实例讲述了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_NAMEconnect 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数据库程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
创建一个dblink,命名为dblink_name,从A数据库连到B数据库,B数据库的IP为192.168.1.73,端口为1521,实例名为oracle,登录
Oracle分页查询的实例详解1.Oracle分页查询:SELECT*FROM(SELECTA.*,ROWNUMRNFROM(SELECT*FROMtab)AW
本文简述了通过创建databaselink实现ORACLE跨数据库查询的方法1.配置本地数据库服务器的tnsnames.ora文件$vi$ORACLE_HOME
本文实例讲述了oracle基本查询操作子查询用法。分享给大家供大家参考,具体如下:一、子查询语法SELECTselect_listFROMtableWHEREe
php访问oracle存储过程实例详解比如我的本地Oracle数据库有一个package,里面有一个存储过程:createorreplacepackagePKG