1、如果需要创建全局 DBLink,则需要先确定用户有创建 dblink 的权限:
- select * from user_sys_privs where privilege like upper('%DATABASE LINK%');
如果没有,则需要使用 sysdba 角色给用户赋权:
- grant create public database link to dbusername;
2、使用该用户登录 PL/SQL,使用命令:
- -- 第一种方法:要求数据库服务器 A 上 tnsnames.ora 中有 数据库 B 的映射
- -- -- create database link 数据库链接名 connect to 用户名 identified by 密码 using '本地配置的数据的实例名';
采用图形配置界面则如下所示:
- -- 第二种方法:直接配置
- -- 如果创建全局 dblink,必须使用 systm 或 sys 用户,在 database 前加 public。
- create /* public */ database link dblink1
- connect to dbusername identified by dbpassword
- using '(DESCRIPTION =(ADDRESS_LIST =(ADDRESS =(PROTOCOL = TCP)(HOST = 192.168.0.1)(PORT = 1521)))(CONNECT_DATA =(SERVICE_NAME = orcl)))';
- -- 数据库参数 global_name=true 时要求数据库链接名称跟远端数据库名称一样。数据库全局名称可以用以下命令查出
- -- select * from global_name;
3、查询数据:
- -- 查询、删除和插入数据和操作本地的数据库是一样的,只不过表名需要写成“表名@dblink服务器”而已。
- select xxx FROM 表名@数据库链接名;
4、删除 DBLink
- drop /* public */ database link dblink1;
5、创建和删除同义词
- create or replace synonym 同义词名 for 表名;
- create or replace synonym 同义词名 for 用户.表名;
- create or replace synonym 同义词名 for 表名@数据库链接名;
- drop synonym 同义词名;
6、创建和删除视图
- create or replace view 视图名 as (select 字段 from 用户.表名@dblink1);
- drop view 视图名;
7、注意:
创建 DBLink 很简单,但是在使用中后台却出现锁,查看这个锁的方法可以去 console 中看到或者查询数据库。每次使用dblink查询的时候,均会与远程数据库创建一个连接,dblink 应该不会自动释放这个连接,如果是大量使用 dblink 查询,会造成 web 项目的连接数不够,导致系统无法正常运行,导致系统无正常运行。
参考文章:
1、http://www.cnblogs.com/sishierfei/archive/2010/12/20/1911606.html
2、http://www.51testing.com/?uid-194762-action-viewspace-itemid-90513
3、http://hi.baidu.com/jjpx/blog/item/a583742451884f124c088dbe.html
相关推荐
oracle 创建dblink的详细步骤,以及使用oracle快照快速的刷新,保持本地与远程数据库的同步
oracle通过DBlink连接mysql搭建过程
Oracle建立DBLINK的详细步骤记录
oracle创建dblink 连接远程服务器,创建连接。
此文档详细的介绍了oracle建立dblink的步骤。
在oracle中创建dblink可以连接其它的oracle数据库。对其它的oracle数据库进行操作。
Oracle创建DBlink连接MYSQL数据库
主要介绍了oracle创建dblink方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
oracle通过ODBC建立dblink访问SqlServer数据库配置
oracle通过odbc方式,连接到sqlserver数据库。比透明网关方式更加简单
本文详细描述了在oracle10g或11g中使用dblink访问sql server,使用oracle的透明网关来访问异构的数据库,方便一些习惯使用oracle的开发人员操作sql server数据库
通过dblink连接oracle和mysql,将数据从oracle传输到mysql,详细记录了搭建过程和创建报错
oracle 使用dblink方式 连接远程数据库,内有详细描述,亲测可以
俩台不同的数据库服务器,从一台数据库服务器的一个用户读取另一台数据库服务器下的某个用户的数据,这个时候可以使用dblink。
本周由于公司一个系统的oracle数据库需要采集另一个系统mysql数据库的数据,于是对oracle通过dblink连接mysql进行了研究,测试环境是单实例oracle 10g 64位,折腾了半天搞定了,但是生产环境是10g rac,原本以为会很...
主要介绍了Oracle DATABASE LINK(DBLINK)创建与删除方法,需要的朋友可以参考下
ORACLE_建立DBLINK详细讲解.pdf
oralce创建dblink的三种方法,修改ora文件、sql创建、通过service创建