数据泵IMPDP 导入工具的使用

简介: --=================================--数据泵IMPDP 导入工具的使用--=================================        数据的导入导出时数据库经常处理的作业之一,Oracle 提供了IMP和IMPDP以及SQL*Loader等工具来完成数据的导入工作,其中IMP服务于早期的9i之前的版本,在10g及后续版本,Oracle 提供了数据泵高速导入工具,本文主要介绍IMPDP的使用方法,关于高速导出工具请参照:数据泵EXPDP 导出工具的使用。

--=================================

--数据泵IMPDP 导入工具的使用

--=================================

   

    数据的导入导出时数据库经常处理的作业之一,Oracle 提供了IMPIMPDP以及SQL*Loader等工具来完成数据的导入工作,其中IMP服务于早期的9i之前的版本,在10g及后续版本,Oracle 提供了数据泵高速导入工具,本文主要介绍IMPDP的使用方法,关于高速导出工具请参照:数据泵EXPDP 导出工具的使用SQL*Loader请参照:SQL*Loader使用方法

 

一、数据泵的体系结构

    数据泵的体系结构在数据泵EXPDP 导出工具的使用已列出,再此不再赘述。

 

二、IMPDP支持的接口及导入模式

    导入接口

        使用命令行带参数的

        使用命令行带参数文件

        使用命令行交互

        使用database console(GUI)

    几种常用的导入模式

        导入表

        导入方案

        导入表空间

        导入数据库

        传输表空间模式

               

       

三、演示如何导入

    1.关于查看impdp的帮助,使用以下命令

        [oracle@oradb ~]$ impdp -?  [oracle@oradb ~]$ impdp -help  前者提供帮助信息并开启命令行交互模式

   

    2. 导入表

        --将表dept,emp导入到scott方案中

        impdp scott/tiger directory=dump_scott dumpfile=tab.dmp tables=dept,emp

 

        --将表deptempscott方案导入到system方案中,对于方案的转移,必须使用remap_shcema参数

        impdp system/manage directory=dump_scott dumpfile=tab.dmp tables=scott.dept,scott.emp remap_schema=scott:system

 

    3.导入方案

        --dump_scott目录下的schema.dmp导入到scott方案中

        impdp scott/tiger directory=dump_scott dumpfile=schema.dmp schemas=scott

       

        --scott方案中的所有对象转移到system方案中

        impdp system/redhat directory=dump_scott dumpfile=schema.dmp schemas=scott remap_schema=scott:system

 

    4.导入表空间

        impdp system/redhat directory=dump_scott dumpfile=tablespace.dmp tablespaces=user01

       

    5.导入数据库

        impdp system/redhat directory=dump_scott dumpfile=full.dmp full=y      

       

    6.将数据对象原样导回(演示从Windows客户端来实现,数据库基于Linux系统)

        Windows客户端来导出scott.emp表,导出后删除该表,再原样导回

        C:/>expdp scott/tiger@list2 directory=dump_scott dumpfile=emp.dmp tables=emp

       

        C:/>sqlplus scott/tiger@list2

 

        SQL*Plus: Release 10.2.0.1.0 - Production on 星期一920 20:50:35 2010

 

        Copyright (c) 1982, 2005, Oracle.  All rights reserved.

 

        Connected to:

        Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production

        With the Partitioning, OLAP and Data Mining options

 

        SQL> drop table emp;

 

        Table dropped.

 

        SQL> commit;

 

        Commit complete.

        SQL> select count(1) from emp;

        select count(1) from emp

                             *

        ERROR at line 1:

        ORA-00942: table or view does not exist

        SQL> host impdp scott/tiger@list2 directory=dump_scott dumpfile=emp.dmp

 

        SQL> select count(1) from emp;

          COUNT(1)

        ----------

                14     

 

    7.将导出的对象使用remap_schema参数转移到不同的方案

        a.deptscott用户导入到system用户下

            expdp scott/tiger directory=dump_scott dumpfile=dept.dmp tables=dept

               

            方法一:

            impdp system/redhat tables=scott.dept directory=dump_scott dumpfile=dept.dmp remap_schema=scott:system

 

            方法二:

            sql>grant imp_full_database to scott;

            impdp scott/tiger directory=dump_scott dumpfile=dept.dmp tables=dept

                  remap_schema=scott:system table_exists_action=replace

   

        b.scott方案下的所有对象导入到system方案下

            expdp scott/tiger directory=dump_scott dumpfile=allobj.dmp schemas=scott

            impdp scott/tiger directory=dump_scott dumpfile=allobj.dmp remap_schema=scott:system table_exists_action=replace

 

    8.使用remap_datafile参数转移到不同的数据文件(用于不同平台之间存在不同命名方式时)

        下面的示例首先创建了一个参数文件,参数文件名为payroll.par

            directory=pump_scott

            full=y

            dumpfile=datafile.dmp

            remap_datafile='db$:[hrdata.payroll]tbs2.f':'/db/hrdata/payroll/tbs2.f'  --指明重新映射数据文件

   

            impdp scott/tiger PARFILE=payroll.par

   

    9.使用remap_tablespace参数转移到不同的表空间

        impdp scott/scott remap_tablespace=users:tbs1 directory=dpump_scott dumpfile=users.dmp

       

    10.并行导入:

        expdp e/e directory=dump_e dumpfile=a_%u.dmp schemas=e parallel=3

 

        impdp e/e directory=dump_e dumpfile=a_%u.dmp schemas=e parallel=3 table_exists_action=replace

 

四、数据泵impdp参数:

    1.REMAP_DATAFILE

        该选项用于将源数据文件名转变为目标数据文件名,在不同平台之间搬移表空间时需要该选项.

        REMAP_DATAFILE=source_datafie:target_datafile

 

    2.REMAP_SCHEMA

        该选项用于将源方案的所有对象装载到目标方案中.

        REMAP_SCHEMA=source_schema:target_schema

 

    3.REMAP_TABLESPACE

        将源表空间的所有对象导入到目标表空间中

        REMAP_TABLESPACE=source_tablespace:target:tablespace

 

    4.REUSE_DATAFILES

        该选项指定建立表空间时是否覆盖已存在的数据文件.默认为N

        REUSE_DATAFIELS={Y | N}

 

    5.SKIP_UNUSABLE_INDEXES

        指定导入是是否跳过不可使用的索引,默认为N

 

    6,sqlfile  参数允许创建DDL 脚本文件

        impdp scott/tiger directory=dump_scott dumpfile=a1.dmp sqlfile=c.sql

        默认放在directory下,因此不要指定绝对路径

 

    7.STREAMS_CONFIGURATION

        指定是否导入流元数据(Stream Matadata),默认值为Y.

 

    8.TABLE_EXISTS_ACTION

        该选项用于指定当表已经存在时导入作业要执行的操作,默认为SKIP

        TABBLE_EXISTS_ACTION={SKIP | APPEND | TRUNCATE | FRPLACE }

 

        当设置该选项为SKIP,导入作业会跳过已存在表处理下一个对象;

        当设置为APPEND,会追加数据

        当设置为TRUNCATE,导入作业会截断表,然后为其追加新数据;

        当设置为REPLACE,导入作业会删除已存在表,重建表并追加数据,

        注意,TRUNCATE选项不适用与簇表和NETWORK_LINK选项

 

    9.TRANSFORM

        该选项用于指定是否修改建立对象的DDL语句

        TRANSFORM=transform_name:value[:object_type]

        transform_name用于指定转换名,其中SEGMENT_ATTRIBUTES用于标识段属性(物理属性,存储属性,表空间,日志等信息),

        STORAGE用于标识段存储属性,VALUE用于指定是否包含段属性或段存储属性,object_type用于指定对象类型.

 

        Impdp scott/tiger directory=dump dumpfile=tab.dmp transform=segment_attributes:n:table

 

    10.TRANSPORT_DATAFILES

        该选项用于指定搬移空间时要被导入到目标数据库的数据文件

        TRANSPORT_DATAFILE=datafile_name

        Datafile_name用于指定被复制到目标数据库的数据文件

        Impdp system/manager DIRECTORY=dump DUMPFILE=tts.dmp

        TRANSPORT_DATAFILES=/user01/data/tbs1.f’

 

五、影响数据泵性能的相关参数

        对下列参数建议如下设置

        disk_asynch_io=true

        db_block_checking=false

        db_block_checksum=false

 

        对下列参数建议设置更高的值来提高并发

        processes                    

        sessions   

        parallel_max_servers                

       

        对下列参数应尽可能的调大空间大小

        shared_pool_size                   

        undo_tablespace                    

 

六、更多参考

 

Oracle 冷备份

 

SPFILE错误导致数据库无法启动

 

Oracle 用户、对象权限、系统权限

 

Oracle 角色、配置文件

 

  Oracle 联机重做日志文件(ONLINE LOG FILE)

 

  Oracle 控制文件(CONTROLFILE)

 

  Oracle 表空间与数据文件

 

Oracle 归档日志

 

 

 

目录
相关文章
|
存储 SQL Oracle
Oracle使用expdp/impdp实现全库导入导出的整体流程
Oracle的全库导入,首先一点必须先创建数据库,创建了数据库,才能往该数据库导入所有数据。相对来说,使用Oracle进行数据导入导出还很有些“麻烦”的,大多数资料上来就是......
9593 0
Oracle使用expdp/impdp实现全库导入导出的整体流程
|
Oracle 关系型数据库 数据库
通过数据泵expdp、impdp方式备份与还原(导出与导入)Oracle数据库
通过数据泵expdp、impdp方式备份与还原(导出与导入)Oracle数据库
|
Oracle 关系型数据库 数据库
Oracle expdp impdp导出导入命令及数据库备份
Oracle expdp impdp导出导入命令及数据库备份
311 0
|
Oracle 关系型数据库
PLSQL_数据泵导入进度查看Impdp/Expdp Status(案例)
20150701 Created By BaoXinjian 一、摘要 查看EXPDP/IMPDP的进度,当你当如导出的时候,如果数据量比较大,中途有些人会着急,不免想看看进度如何 1. 两个视图 DBA_DATAPUMP_JOBS; DBA_DATAPUMP_SESSIONS; 2.
3323 0
|
机器学习/深度学习 Oracle 关系型数据库
【expdp】10g数据泵expdp工具选项详解及应用示例
理解expdp各个选项的含义最好的途径就是逐一的进行测试,这样可以在感性上有一个真实的体验。 1.数据泵expdp导出工具与传统的exp导出工具的区别 1)exp是客户端程序,既可以在客户端使用,也可以在服务器端使用; 2)expdp是服务器端工具,只能在ORACLE服务器端使用,不能在客户端使用; 3)这两个工具生成的备份文件不能被对方与之对应的导入工具使用; 4)expdp在灵活性和功能性上与exp相比,有质上的飞跃。 2.expdp命令行选项列表 使用“-help”选项获得expdp命令可用的选项列表和简单的注释信息。 ora10g@linux5 /expdp$ expdp help
359 0
|
Oracle 关系型数据库 数据库
expdp 导出简单笔记
expdp 导出简单笔记 1、要创建oracle可访问的目录必须赋予oracle:oinstall的权限 [root@oracle/]# chown -R oracle:oinstall /data1 2、切换到oracle用户 [roo...
919 0
|
Oracle 关系型数据库 数据库
Oracle之数据泵导入/导出数据
以前习惯用imp/exp导入导出数据,现在我们来搞一把数据泵导入导出的方法。它比之于imp/exp的方式的优点自不必说---速度快! 但是很不幸,我在导出数据的时候报错了,我擦,这特么就尴尬了。
1412 0
|
Oracle 关系型数据库 数据库