oracle中的database link是定义一个数据库到另一个数据库的路径的对象,database link允许你查询远程表和执行远程程序。在任何分布式环境里,dblink都是必要的,另外注意database link是单向的连接。在创建database link的时候,oracle在数据字典中存储了相关的database link的信息,在使用database link的时候,oracle再通过oracle net用户预先定义好的连接信息访问相应的远程数据库来完成相应的工作。
1、在建立database link之前需要注意:
(1)确认从local database到remote database的网络连接是否正常,tnsping要能成功。
(2)确认在remote database上面有相应的访问权限。
2、oracle database link可分为下面三类:
(1)private:创建的是用户级别的dblink,只有创建该dblink的用户才可以使用这个dblink来访问远程的数据库,同时也只有该用户可以删除这个dblink。
(2)public:创建的是数据库级别的dblink,本地数据库中所有的用户数据库访问权限的用户或者pl/sql程序都能使用这个dblink。
(3)global:创建的是网络级别的dblink,这是对于oracle network而言的。
3、创建dblink需要的权限:
如果你新建了一个用户,那么你必须为它授予以下权限才可以创建dblink:create database link、create public database link、create session。
4、创建dblink:
点击(此处)折叠或打开
-
-- 如果不指定public,默认的是private,host后面可以是ip地址,也可以是解析过的域名
CREATE PUBLIC DATABASE LINK dl_OCPLYZ1 CONNECT TO lyz IDENTIFIED BY lyz
USING '(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.95.155)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = OCPLYZ1)
)
)';
或者我们可以这样写:
create public database link dl_OCPLYZ1 connect to lyz identified by lyz using 'OCPLYZ1';
但是要再 tnsnames.ora 文件上加上这个:OCPLYZ1 ,这个格式最好要和上面的对应规整点。。。。否则有可能认不到。。
然后上面的 using 'OCPLYZ1' 这边就要和tnsnames.ora 名字一样了

5、查看dblink:
查看dblink,可以从dba_objects、dba_db_links这两张表去查:
点击(此处)折叠或打开
-
SELECT * FROM dba_objects do WHERE do.OBJECT_TYPE = 'DATABASE LINK';
SELECT * FROM dba_db_links ddl;
除了上面两张表,还有all_db_links、user_db_links。
6、使用dblink:
点击(此处)折叠或打开
-
-- 最简单的用法
SELECT * FROM table_name@database_link;
-- 不想让别人知道database link名字的时候,可以使用同义词包装一下
CREATE SYNONYM table_name for table_name@database_link;
SELECT * FROM table_name;
-- 也可以建立一个视图来封装
CREATE VIEW table_name_v AS SELECT * FROM table_name@database_link;
点击(此处)折叠或打开
-
-- 删除public类型的dblink
DROP PUBLIC DATABASE LINK dblink_name;
-- 删除private类型的dblink,只有创建者自己能删
DROP DATABASE LINK dblink_name;
如果我们要使用expdp ,然后要像实现exp一样,把这个dmp文件,给它倒到本地,那么我们应该怎么实现呢。。。。。。?
我们可以用连接 dblink的方法来导出:也就是说我们要用到两个库:
例子:我们可以从远程数据库倒入到本地数据库。。。。
1 我们首先要在本地数据库创建一个dblink
连接到:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
再本地数据库创建一个dblink :
SQL> create public database link dl_OCPLYZ1 connect to lyz identified by lyz us
ing 'OCPLYZ1';
数据库链接已创建。
SQL>
'OCPLYZ1' 这边的 OCPLYZ1我已经再 tnsnames.ora 那边配好了:

我们可以简单的远程检查下数据库能不能通:查得到说明创建成功
点击(此处)折叠或打开
-
SQL> select count(1) from lyz.EMPLOYEES2@dl_OCPLYZ1;
COUNT(1)
----------
4
SQL>
我们可以在 client 端或目标数据库执行。。。。
我们这边是直接在本地执行:
我们可以先查下本地ip 是多少:ipconfig:查得ip 172.17.146.3 ,但由于本地数据库是直接安装再win 7电脑上的,所以我本地就是目标数据库啦。。。。
倒出命令如下:这边说明下:这边的倒出是基于 表的倒出。。。。。
点击(此处)折叠或打开
-
expdp scott/tiger@172.17.146.3/orcl directory=DATA_PUMP_DIR dumpfile=exptable.dmp TABLES=lyz.TESTA network_link=dl_OCPLYZ1 LOGFILE=expdp_table.log;
这边的 expdp 倒出一定是要本地的数据库,也就是目标数据库的用户 和服务名
-
expdp scott/tiger@172.17.146.3/orcl
-
network_link=dl_OCPLYZ1
-
TABLES=lyz.TESTA

也就是说,如果不加 用户来源:lyz.testa 表,数据库应该是默认成你这个
-
TABLES=TESTA
当然如果你目标库(本地数据库)有这个lyz 这个用户,我们也可以这样写:
点击(此处)折叠或打开
-
expdp lyz/lyz@172.17.146.3/orcl directory=DATA_PUMP_DIR dumpfile=exptable.dmp TABLES=TESTA network_link=dl_OCPLYZ1 LOGFILE=expdp_table.log;

然后我们可以到本地看下结果: 这个 exptable.dmp 文件就是从 远程数据库倒下来的数据来。。。。。

然后我们再倒入到库就可以 了:这边要倒入的数据库为:oracl
由于上面的是基于表的导出,我们可以用下面这个命令:
impdp scott/tiger@orcl DIRECTORY=DATA_PUMP_DIR DUMPFILE=exptable.dmp TABLES=lyz.TESTA REMAP_SCHEMA=lyz:scott table_exists_action=REPLACE

这边的意思是:impdp 倒入到 oracl库下的用户,倒入的路径为DATA_PUMP_DIR,倒入的dmp 文件为:exptable.dmp ,倒入的表为:TABLES=lyz.TESTA ,REMAP_SCHEMA=lyz:scott : 这边的意思是 从 lyz用户到scott用户,table_exists_action=REPLACE : 这边的意思是:如果表存在,就直接替换掉。
或者是基于用户的倒入:去掉这个TABLES=lyz.TESTA,但是也是 lyz 用户到 scott用户
impdp scott/tiger@orcl DIRECTORY=DATA_PUMP_DIR DUMPFILE=exptable.dmp REMAP_SCHEMA=lyz:scott table_exists_action=REPLACE

好了,这个就是 利用 db_link 的expdp 、impdp的导出导入。。。。。。。
编辑推荐:
- word2010带圈字符如何设置03-03
- oracle dblink用法总结和expdp和impdp利用dblink倒入导出到本地03-03
- Word2010如何设置文字垂直居中03-03
- word2010如何插入页码03-03
- Word2010如何制作成绩表03-03
- word2010段落边框如何设置03-03
- word2010如何绘制表格03-03
- word2010段落间距如何设置03-03
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
热文推荐
- 【TTS】AIX->Linux--基于RMAN(真实环境)--续
【TTS】AIX->Linux--基于RMAN(真实环境)--续
26-03-03 - oracle dblink用法总结和expdp和impdp利用dblink倒入导出到本地
- Maya建模教程:制作真实的恐龙
Maya建模教程:制作真实的恐龙
26-03-03 - Oracle权限管理详解
Oracle权限管理详解
26-03-03 - Oracle中的sysctl.conf内核参数
Oracle中的sysctl.conf内核参数
26-03-03 - [Oracle 11g r2(11.2.0.4.0)]集群术语和参数简介
[Oracle 11g r2(11.2.0.4.0)]集群术语和参数简介
26-03-03 - ORA-00600: internal error code, arguments: [4000], [5]
- 备份的相关概念
备份的相关概念
26-03-03 - RAC性能分析gc buffer busy acquire 等待事件
RAC性能分析gc buffer busy acquire 等待事件
26-03-03 - MAMY绘制游戏中的魔法机器人实例
MAMY绘制游戏中的魔法机器人实例
26-03-03
