oracle跨库查询dblink的用法实例详解
2015-12-11 00:00
726 查看
本文实例讲述了oracle跨库查询dblink的用法。分享给大家供大家参考,具体如下:
1.创建之前的工作
在创建dblink之前,首先要查看用户是否有相应的权限。针对特定的用户,使用 sqlplus user/pwd登录后,执行如下语句:
在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用户下修改:
查看dblink,有两种方式,分别如下:
①.
②.
2. 创建dblink
注意:using后跟的是一个字符串,其中一定不要出现不必要的空格,否则会出错ORA-12514,在上面的代码中为了方便阅读其中进行了换行,可能会出现空格而导致错误,所以使用的时候将空格去掉就ok了。
这里LINK_NAM为自定的名称;USERNAME和PASSWORD为指定的oracle数据库中的用户名和密码,SERVICE_NAME如果不确定的话,可以通过以下语句获得:
或者
3.dblink的使用
dblink的使用相对比较简单,把一般访问本地表时的表名改为如下格式即可:[user.]table@link_name。
4.删除dblink
确定要删除的dblink名字以后,可以通过drop命令直接将其删除:
希望本文所述对大家Oracle数据库程序设计有所帮助。
一些Oracle数据库中的查询优化建议综合
Oracle数据库中ORDER BY排序和查询按IN条件的顺序输出
Oracle中查看慢查询进度的脚本分享
Oracle 跨库 查询 复制表数据 分布式查询介绍
Oracle实现分页查询的SQL语法汇总
ORACLE学习笔记-查询篇
整理Oracle数据库中数据查询优化的一些关键点
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数据库程序设计有所帮助。
您可能感兴趣的文章:
Oracle数据库中基本的查询优化与子查询优化讲解一些Oracle数据库中的查询优化建议综合
Oracle数据库中ORDER BY排序和查询按IN条件的顺序输出
Oracle中查看慢查询进度的脚本分享
Oracle 跨库 查询 复制表数据 分布式查询介绍
Oracle实现分页查询的SQL语法汇总
ORACLE学习笔记-查询篇
整理Oracle数据库中数据查询优化的一些关键点
相关文章推荐
- Oracle修改表空间大小的方法
- LINUX下Oracle数据导入导出的方法详解
- LINUX下Oracle数据库用户创建方法详解
- Linux下Oracle删除用户和表空间的方法
- 有关jdk和oracle和eclipse问题
- oracle 表连接
- oracle数据库查询语句的执行顺序
- ORACLE数据类型
- 连接Oracle与Hadoop(1) 使用OLH加载HDFS文件到Oracle
- oracle中默认的编码格式
- oracle中进行两个字符串的连接的函数
- Java笔记4:JDBC纯驱动方式连接Oracle
- 查看oracle数据库的连接数以及用户
- Oracle中查看无效的对象、约束、触发器和索引(转自Helloblock)
- oracle删除表了如何恢复数据以及如何把一张表的数据复制到另一张表
- Oracle ASM操作管理
- oracle 设置自增字段
- 如何查询Oracle中所有用户信息
- 将外部数据导入oracle
- Oracle FND API–Create User