中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档 | 网通镜像
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 数据库开发 > Oracle
利用Oracle数据泵完成数据导入和导出
作者:yuanshang 时间:2007-06-15 17:09 出处:ccidnet.com 责编:月夜寒箫
              摘要:利用Oracle数据泵完成数据导入和导出

在Oracle 10g中, exp 和 imp 被重新设计为Oracle Data Pump(虽然Oracle 仍然装载了exp 和imp,并完全地支持它们)。如果你以前使用过exp 和 imp,那么Data Pump 的命令行程序的语法对你来说就不陌生了。

Data Pump 是运行在数据库内部的, 而不是像一个独立的客户端应用程序一样存在。这就意味着这部分的工作在一定程度上独立于发起执行导入或者导出任务的进程 。 在一台机器上 (例如一个定期任务) 可以开始执行导出的任务,而另一台机器上 (例如 DBA 的 手提电脑) 可以对任务的运行状态进行监控。 也正因为任务是运行在数据库内部的,所以如果你要将数据导出到一个文件中,那么你首先要做的事情就是为输出路径建立一个数据库的DIRECTORY 对象,然后给将要进行数据导入和导出的用户授权访问,命令如下:

 

 
              create or replace directory dumpdir as 'c:\';
              
              grant read,write on directory dumpdir to scott;
             
 

一旦该路经被授权后,就可以通过以下的命令参数导出用户的对象,这些命令与 exp 和 imp 中的命令非常相似:

 

 
              expdp scott/tiger directory=dumpdir dumpfile=scott.dmp
  

当导出工作开始执行以后,可以通过按下[Ctrl]C (或者是客户端中具有相同功能的按键) 来“中止”导出任务。这样就不会再有数据发送到你的客户端了,但是该任务在数据库中仍然还在运行。你的客户端会进入交互模式(出现Export>提示符)。 在提示符后输入status就可以查看到当前有哪些任务正在运行。如果在客户端输入expdp attach=<任务名>,你就可以连接到一个正在运行的任务上。

Data Pump 并不是一定要写入到文件中。现在可以通过选项设置就可以将数据库对象通过SQL*Net直接导到一个远程数据库中。你所要做的就仅仅是指定remote 选项,然后加上与远程数据库连接的连接字符串。 这就有点类似于对数据库的一次性复制过程。

Data Pump 执行起来要比原来的exp 和 imp 客户端命令快得多。Data Pump 运行得更快是因为它有一个新特性——“parallel”选项。选定这个选项后,Data Pump 将会以四个不同的线程同时压送数据。下面举个例子,我先执行下面的任务,然后按 [Ctrl]C,接着察看后台任务的状态:

 

 
              expdp scott/tiger directory=dumpdir dumpfile=scott2.dmp parallel=4
              job_name=scott2
              
              Export: Release 10.1.0.2.0 - Production on Friday, 31 December, 2004 14:54
              
              Copyright (c) 2003, Oracle. All rights reserved.
              
              Connected to: Oracle Database 10g Enterprise Edition Release 10.1.0.2.0 -
              Production
              With the Partitioning, OLAP and Data Mining options
              FLASHBACK automatically enabled to preserve database integrity.
              Starting "SCOTT"."SCOTT2": scott/******** directory=dumpdir
              dumpfile=scott2.dmp parallel=4 job_name=scott2
              Estimate in progress using BLOCKS method...
              
              Export> status
              
              Job: SCOTT2
              Operation: EXPORT
              Mode: SCHEMA
              State: EXECUTING
              Bytes Processed: 0
              Current Parallelism: 4
              Job Error Count: 0
              Dump File: C:\SCOTT2.DMP
              bytes written: 4,096
              
              Worker 1 Status:
              State: EXECUTING
              
              Worker 2 Status:
              State: WORK WAITING
              
              Worker 3 Status:
              State: WORK WAITING
              
              Worker 4 Status:
              State: WORK WAITING
  

其实不仅仅只有Data Pump 是在数据库内部运行的,事实上大部分的命令行性质的命令都是在数据库内部运行的,只不过是通过一个PL/SQL API—— DBMS_DATAPUMP显示出来。例如,可以通过以下的PL/SQL代码来实现通过PL/SQL 包启动导出任务:

 

 
              declare
              handle number;
              begin
              handle := dbms_datapump.open('EXPORT','SCHEMA');
              dbms_datapump.add_file(handle,'SCOTT3.DMP','DUMPDIR');
              dbms_datapump.metadata_filter(handle,'SCHEMA_EXPR','= 'SCOTT'');
              dbms_datapump.set_parallel(handle,4);
              dbms_datapump.start_job(handle);
              dbms_datapump.detach(handle);
              end; /
  

仔细研究 Data Pump ,你可以了解到 Data Pump 其他更多的新特性。例如,Data Pump 可以对数据文件重命名,可以将对象移动到不同的表空间中,还可以通过使用通配符结构或者是语句来查找图表对象或是图表。Data Pump 还可以用作外部表的接口 (例如,可以将一个表与存储在一个数据泵导出文件中的数据关联起来,这就像Oracle 9i 以及更高版本中的Oracle Loader 接口一样)。

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有