oracle跨库查询dblink的用法实例详解
本文实例讲述了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
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如果不确定的话,可以通过以下语句获得:
或者
3.dblink的使用
dblink的使用相对比较简单,把一般访问本地表时的表名改为如下格式即可:[user.]table@link_name。
4.删除dblink
确定要删除的dblink名字以后,可以通过drop命令直接将其删除:
希望本文所述对大家oracle数据库程序设计有所帮助。
上一篇: 12代酷睿i9-12900KS特别版曝光:全核加速5.2GHz
下一篇: 可以不要小孩
推荐阅读
-
用实例详解Python中的Django框架中prefetch_related()函数对数据库查询的优化
-
Oracle数据库根据时间范围查询时间范围内的年,月,日以及一天的24小时(实例)
-
Oracle的NVL函数用法、Oracle递归查询实例讲解
-
oracle数据库定时任务dbms_job的用法详解
-
oracle数据库的同义词Synonym与dblink关联,从而可以直接查询远程数据库的表,不用指定用户和@指定dblink名称
-
Laravel5.1 框架数据库查询构建器用法实例详解
-
Oracle查询库中所有表名、字段名、字段名说明,查询表的数据条数、表名、中文表名等实例教程
-
ORACLE最高效的分页之分页查询SQL语法实例详解
-
oracle跨库查询的方法
-
oracle数据库中sql%notfound的用法详解