oracle数据泵管理 -数据泵使用汇总

文章 转载于http://blog.csdn.net/demo_lomo/article/details/52035748

总览:

数据库导入的的一个经典parfile

sqlplus xxxx/******** \
    DIRECTORY=xxxx \
    DUMPFILE=xxxx_%U.dmp \
    REMAP_SCHEMA=xxxx:xxxx \
    REMAP_TABLESPACE=xxxx:xxxx \
    REMAP_TABLE=xxxx:xxxx \
    TABLES=xxxx \
    LOGFILE=xxxx.log \
    TABLE_EXISTS_ACTION=REPLACE \
    PARALLEL=4 \
    INCLUDE=TABLE/TABLE,TABLE/TABLE_DATA
 

expdp systme/123 dumpfile=pump:123_%U.DMP LOGFILE=PUMP:123.LOG SCHEMAS=USSER1,USER2 CONTENT=metadata_only exlude=statistics

启动 "SYSTEM"."SYS_EXPORT_FULL_01":  system/******** full=y
处理对象类型 DATABASE_EXPORT/EARLY_OPTIONS/VIEWS_AS_TABLES/TABLE_DATA
处理对象类型 DATABASE_EXPORT/NORMAL_OPTIONS/TABLE_DATA
处理对象类型 DATABASE_EXPORT/NORMAL_OPTIONS/VIEWS_AS_TABLES/TABLE_DATA
处理对象类型 DATABASE_EXPORT/SCHEMA/TABLE/TABLE_DATA
处理对象类型 DATABASE_EXPORT/SCHEMA/TABLE/INDEX/STATISTICS/INDEX_STATISTICS
处理对象类型 DATABASE_EXPORT/SCHEMA/TABLE/STATISTICS/TABLE_STATISTICS
处理对象类型 DATABASE_EXPORT/STATISTICS/MARKER
处理对象类型 DATABASE_EXPORT/PRE_SYSTEM_IMPCALLOUT/MARKER
处理对象类型 DATABASE_EXPORT/PRE_INSTANCE_IMPCALLOUT/MARKER
处理对象类型 DATABASE_EXPORT/TABLESPACE
处理对象类型 DATABASE_EXPORT/PROFILE
处理对象类型 DATABASE_EXPORT/SYS_USER/USER
处理对象类型 DATABASE_EXPORT/SCHEMA/USER
处理对象类型 DATABASE_EXPORT/RADM_FPTM
处理对象类型 DATABASE_EXPORT/GRANT/SYSTEM_GRANT/PROC_SYSTEM_GRANT
处理对象类型 DATABASE_EXPORT/SCHEMA/GRANT/SYSTEM_GRANT
处理对象类型 DATABASE_EXPORT/SCHEMA/ROLE_GRANT
处理对象类型 DATABASE_EXPORT/SCHEMA/DEFAULT_ROLE
处理对象类型 DATABASE_EXPORT/SCHEMA/ON_USER_GRANT
处理对象类型 DATABASE_EXPORT/SCHEMA/TABLESPACE_QUOTA
处理对象类型 DATABASE_EXPORT/RESOURCE_COST
处理对象类型 DATABASE_EXPORT/SCHEMA/DB_LINK
处理对象类型 DATABASE_EXPORT/TRUSTED_DB_LINK
处理对象类型 DATABASE_EXPORT/SCHEMA/SEQUENCE/SEQUENCE
处理对象类型 DATABASE_EXPORT/DIRECTORY/DIRECTORY
处理对象类型 DATABASE_EXPORT/DIRECTORY/GRANT/OWNER_GRANT/OBJECT_GRANT
处理对象类型 DATABASE_EXPORT/SYSTEM_PROCOBJACT/PRE_SYSTEM_ACTIONS/PROCACT_SYSTEM

处理对象类型 DATABASE_EXPORT/SYSTEM_PROCOBJACT/PROCOBJ
处理对象类型 DATABASE_EXPORT/SYSTEM_PROCOBJACT/POST_SYSTEM_ACTIONS/PROCACT_SYSTE
M
处理对象类型 DATABASE_EXPORT/SCHEMA/PROCACT_SCHEMA
处理对象类型 DATABASE_EXPORT/EARLY_OPTIONS/VIEWS_AS_TABLES/TABLE
处理对象类型 DATABASE_EXPORT/EARLY_POST_INSTANCE_IMPCALLOUT/MARKER
处理对象类型 DATABASE_EXPORT/NORMAL_OPTIONS/TABLE
处理对象类型 DATABASE_EXPORT/NORMAL_OPTIONS/VIEWS_AS_TABLES/TABLE
处理对象类型 DATABASE_EXPORT/NORMAL_POST_INSTANCE_IMPCALLOUT/MARKER
处理对象类型 DATABASE_EXPORT/SCHEMA/TABLE/TABLE
处理对象类型 DATABASE_EXPORT/SCHEMA/TABLE/GRANT/OWNER_GRANT/OBJECT_GRANT
处理对象类型 DATABASE_EXPORT/SCHEMA/TABLE/COMMENT
处理对象类型 DATABASE_EXPORT/SCHEMA/PROCEDURE/PROCEDURE
处理对象类型 DATABASE_EXPORT/SCHEMA/PROCEDURE/ALTER_PROCEDURE
处理对象类型 DATABASE_EXPORT/SCHEMA/VIEW/VIEW
处理对象类型 DATABASE_EXPORT/SCHEMA/TABLE/INDEX/INDEX
处理对象类型 DATABASE_EXPORT/SCHEMA/TABLE/CONSTRAINT/CONSTRAINT
处理对象类型 DATABASE_EXPORT/SCHEMA/TABLE/CONSTRAINT/REF_CONSTRAINT
处理对象类型 DATABASE_EXPORT/SCHEMA/TABLE/POST_TABLE_ACTION
处理对象类型 DATABASE_EXPORT/SCHEMA/TABLE/TRIGGER
处理对象类型 DATABASE_EXPORT/SCHEMA/TABLE/MATERIALIZED_VIEW_LOG
处理对象类型 DATABASE_EXPORT/FINAL_POST_INSTANCE_IMPCALLOUT/MARKER
处理对象类型 DATABASE_EXPORT/SCHEMA/POST_SCHEMA/PROCACT_SCHEMA
处理对象类型 DATABASE_EXPORT/AUDIT_UNIFIED/AUDIT_POLICY_ENABLE
处理对象类型 DATABASE_EXPORT/POST_SYSTEM_IMPCALLOUT/MARKER

案例1生成sql脚本

生成sql脚本实际不导入。

oracle数据泵管理 -数据泵使用汇总_第1张图片

C:\Users\Administrator>impdp system/ora#123 dumpfile=data_pump_dir:metadata_eoms.dmp sqlfile=metadatae
oms.sql

impdp username/password dumpfile=dir:123.dmp full=y sqlfile=123.sql  实际不导入

C:\Users\Administrator>expdp system/123 dumpfile=data_pump_dir:12322212.dmp include=default_role full=y

Export: Release 12.2.0.1.0 - Production on 星期二 11月 24 15:24:36 2020

Copyright (c) 1982, 2017, Oracle and/or its affiliates.  All rights reserved.

连接到: Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Produc
tion
启动 "SYSTEM"."SYS_EXPORT_FULL_01":  system/******** dumpfile=data_pump_dir:1232
2212.dmp include=default_role full=y
处理对象类型 DATABASE_EXPORT/SCHEMA/DEFAULT_ROLE
已成功加载/卸载了主表 "SYSTEM"."SYS_EXPORT_FULL_01"
******************************************************************************
SYSTEM.SYS_EXPORT_FULL_01 的转储文件集为:
  D:\APP\ADMINISTRATOR\VIRTUAL\ADMIN\ORCL\DPDUMP\12322212.DMP
作业 "SYSTEM"."SYS_EXPORT_FULL_01" 已于 星期二 11月 24 15:24:44 2020 elapsed 0 0
0:00:06 成功完成


C:\Users\Administrator>impdp system/123 dumpfile=data_pump_dir:12322212.dmp sqlfile=123.sql full=y

Import: Release 12.2.0.1.0 - Production on 星期二 11月 24 15:25:11 2020

Copyright (c) 1982, 2017, Oracle and/or its affiliates.  All rights reserved.

连接到: Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Produc
tion
已成功加载/卸载了主表 "SYSTEM"."SYS_SQL_FILE_FULL_01"
启动 "SYSTEM"."SYS_SQL_FILE_FULL_01":  system/******** dumpfile=data_pump_dir:12
322212.dmp sqlfile=123.sql full=y
处理对象类型 DATABASE_EXPORT/SCHEMA/DEFAULT_ROLE
作业 "SYSTEM"."SYS_SQL_FILE_FULL_01" 已于 星期二 11月 24 15:25:16 2020 elapsed 0
 00:00:03 成功完成
 

案例1导出A1,A2用户下,所有包含TPAXA字符串的表

使用content选项,只导出数据或者 结构

content=metadata_only or data_only

案例1导出A1,A2用户下,所有包含TPAXA字符串的表

SCHEMAS=A1,A2

include=table:"in(SELECT TABLE_NAME FROM DBA_TABLES WHERE TABLE_NAME LIKE ''%TPAXA%')'

dumpfile=EXPDP_DIR:dn_%u.dmp
parallel=5
schemas=dn
include=TABLE:"IN(select segment_name
  from dba_segments
 where bytes / 1024 / 1024 <= 100
   and owner in ('DNMS', 'ARENA', 'FMS')
   AND SEGMENT_TYPE = 'TABLE'
   and segment_name not like 'DI_%'
   and segment_name not like 'IPW%'
   and segment_name not like 'IPA%'
   and segment_name not like 'TFA_AM_DUP%'
   and segment_name not like 'A%'
   and segment_name not like '%K%'
   AND segment_name not like '%MP%')"

job_name=job2
logfile=EXPDP_DIR:dns.log
 

dumpfile=EXPDP_DIR:etadata_%u.dmp
parallel=5
schemas=dn
include=TABLE:"IN(select table_name from tab1)"
CONTENT=metadata_only
job_name=job1
logfile=EXPDP_DIR:mta.log
 

案例2 导出表数据,并进行筛选 

dumpfile=EXPDP_DIR:dnms20201124_01_%u.dmp
logfile=EXPDP_DIR:dnms20201124_01.log
parallel=5
tables=C1.domain_name,C1.iptp
query=C1.domain_name:"where  org_time>sysdate-1",C1.iptp:"where  org_time>sysdate-1"

案例4 导出数据库所有的dblink

C:\Users\Administrator>expdp system/123 dumpfile=data_pump_dir:1232222.dmp include=db_link full=y /schemas=a1

1.1.1 expdp使用

 使用EXPDP工具时,其转储文件只能被存放在DIRECTORY对象对应的OS目录中,而不能直接指定转储文件所在的OS目录.因此使用EXPDP工具时,必须首先建立DIRECTORY对象.并且需要为数据库用户授予使用DIRECTORY对象权限.

数据泵的使用必须在服务器端进行。

首先得建DIRECTORY:

SQL> conn /as sysdba

SQL> CREATE OR REPLACE DIRECTORY dir_dump  AS '/u01/backup/';

SQL> GRANT read,write ON DIRECTORY dir_dump TO public;

查询已有的目录:

select * from dba_directories;
删除路径:
drop directory exp_dir;

exclude

vi 123.PRA

DUMPFILE=

LOGFILE=

PARALLEL=10

SCHEMAS=A1

EXLUCE=TABLE:"IN(SELECT SEGMENT_NAME FROM T1 WHERE A>1)"

1) 导出scott整个schema

--默认导出登陆账号的schema

$ expdp scott/tiger@db_esuite parfile=/orahome/expdp.par 

Windows下面:

$ expdp scott/tiger@db_esuite parfile=d:\orahome\expdp.par

expdp.par内容: 大小写不区分

    DIRECTORY=dir_dump

    DUMPFILE=scott_full.dmp

    LOGFILE=scott_full.log

--其他账号登陆, 在参数中指定schemas

$ expdp system/Oracle@db_esuite parfile=/orahome/expdp.par

expdp.par内容: 

    DIRECTORY=dir_dump

    DUMPFILE=scott_full.dmp

    LOGFILE=scott_full.log

    SCHEMAS=SCOTT

跨版本impdp

10g:

expdp system/zaq1xsw2@cu3gp schemas=ECSAPP_N6,UQUERY,ECSMALLMAN,ECSAPP,REPORT,ECSMALLSHELL,ECSMALLAPP,ECSAPP_HLJ,ECSAPP_HB,ECSAPP_SD,ECSAPP_HN,ECSAPP_BJ,N6_QUERY directory=dump_dir dumpfile=expdp20120727_%U.dmp logfile=exp20120727.log filesize=4000M parallel=8

11g:

impdp system/oracle1@emdb schemas=ECSAPP_N6,UQUERY,ECSMALLMAN,ECSAPP,REPORT,ECSMALLSHELL,ECSMALLAPP,ECSAPP_HLJ,ECSAPP_HB,ECSAPP_SD,ECSAPP_HN,ECSAPP_BJ,N6_QUERY directory=dump_dir dumpfile=expdp20120727_%U.dmp logfile=imp20120727.log  parallel=8 TABLE_EXISTS_ACTION=TRUNCATE VERSION= 10.2.0.5.0
 

2) 导出scott下的dept,emp表

$ expdp scott/tiger@db_esuite parfile=/orahome/expdp.par

expdp.par内容: 

    DIRECTORY=dir_dump

    DUMPFILE=scott.dmp

    LOGFILE=scott.log

    TABLES=DEPT,EMP

如果写为:大小写不区别,指定schemas和tables不能同时使用

   directory=dir_dump

dumpfile=scott.dmp

logfile=scott.log

tables=dept,emp

3) 导出scott下除emp之外的表

$ expdp scott/tiger@db_esuite parfile=/orahome/expdp.par

expdp.par内容: 

    DIRECTORY=dir_dump

    DUMPFILE=scott.dmp

    LOGFILE=scott.log

    EXCLUDE=TABLE:"='EMP'"

Eg:

Impdp serviceworks_0916

 DIRECTORY=dmp_dirDUMPFILE= expbizservice0916.dmp remap_schema=bizservice_0916

:serviceworks_0916 EXCLUDE=INDEX EXCLUDE=REF_CONSTRAINTexclude=table_statistics

 LOGFILE=imp1_tab.log

--导出全库的dblink

4) 导出scott下的存储过程

$ expdp scott/tiger@db_esuite parfile=/orahome/expdp.par

expdp.par内容: 

    DIRECTORY=dir_dump

    DUMPFILE=scott.dmp

    LOGFILE=scott.log

    INCLUDE=PROCEDURE

5) 导出scott下以'E'开头的表

$ expdp scott/tiger@db_esuite parfile=/orahome/expdp.par

expdp.par内容: 

    DIRECTORY=dir_dump

    DUMPFILE=scott.dmp

    LOGFILE=scott.log

    INCLUDE=TABLE:"LIKE 'E%'"   //可以改成NOT LIKE,就导出不以E开头的表

6) 带QUERY导出

$ expdp scott/tiger@db_esuite parfile=/orahome/expdp.par

expdp.par内容: 

    DIRECTORY=dir_dump

    DUMPFILE=scott.dmp

    LOGFILE=scott.log

    TABLES=EMP,DEPT

    QUERY=EMP:"where empno>=8000"

    QUERY=DEPT:"where deptno>=10 and deptno<=40"

注: 处理这样带查询的多表导出, 如果多表之间有外健关联, 可能需要注意查询条件所筛选的数据是否符合这样的外健约束, 比如 EMP中有一栏位是 deptno, 是关联dept中的主键, 如果"where empno>=8000"中得出的deptno=50的话, 那么, 你的dept的条件"where deptno>=10 and deptno<=40"就不包含deptno=50的数据, 那么在导入的时候就会出现错误.

Oracle10g 数据泵导出命令 expdp 使用总结(二)

1.1.2 expdp选项

1. ATTACH

该选项用于在客户会话与已存在导出作用之间建立关联.语法如下:

ATTACH=[schema_name.]job_name

schema_name用于指定方案名,job_name用于指定导出作业名.注意,如果使用ATTACH选项,在命令行除了连接字符串和ATTACH选项外,不能指定任何其他选项,示例如下:

expdp scott/tiger ATTACH=scott.export_job

默认的job名称为:

2. CONTENT

该选项用于指定要导出的内容.默认值为ALL.语法如下:

CONTENT={ALL | DATA_ONLY | METADATA_ONLY}

当设置CONTENT为ALL 时,将导出对象定义及其所有数据; 为DATA_ONLY时,只导出对象数据; 为METADATA_ONLY时,只导出对象定义,示例如下:

expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dump CONTENT=METADATA_ONLY

3. DIRECTORY

指定转储文件和日志文件所在的目录.语法如下:

DIRECTORY=directory_object

directory_object用于指定目录对象名称.需要注意,目录对象是使用CREATE DIRECTORY语句建立的对象,而不是OS 目录,示例如下:

expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dump

建立目录:

CREATE DIRECTORY dump as 'd:\dump';

查询创建了那些子目录:

SQL:\SELECT * FROM dba_directories;

4. DUMPFILE

用于指定转储文件的名称,默认名称为expdat.dmp.语法如下:

DUMPFILE=[directory_object:]file_name[,….]

directory_object用于指定目录对象名,file_name用于指定转储文件名.需要注意,如果不指定directory_object,导出工具会自动使用DIRECTORY选项指定的目录对象,示例如下:

expdp scott/tiger DIRECTORY=dump1 DUMPFILE=dump2:a.dmp

5. ESTIMATE

指定估算被导出表所占用磁盘空间的方法.默认值是BLOCKS.语法如下:

EXTIMATE={BLOCKS | STATISTICS}

设置为BLOCKS时,oracle会按照目标对象所占用的数据块个数乘以数据块尺寸估算对象占用的空间,设置为STATISTICS时,根据最近统计值估算对象占用空间,示例如下:

expdp scott/tiger TABLES=emp ESTIMATE=STATISTICS DIRECTORY=dump DUMPFILE=a.dump

一般情况下, 当用默认值(blocks)时, 日志中估计的文件大小会比实际expdp出来的文件大, 用statistics时会跟实际大小差不多.

6. EXTIMATE_ONLY

指定是否只估算导出作业所占用的磁盘空间,默认值为N.语法如下:

EXTIMATE_ONLY={Y | N}

设置为Y时,导出作用只估算对象所占用的磁盘空间,而不会执行导出作业,为N时,不仅估算对象所占用的磁盘空间,还会执行导出操作,示例如下:

expdp scott/tiger ESTIMATE_ONLY=y NOLOGFILE=y

7. EXCLUDE

该选项用于指定执行操作时要排除的对象类型或相关对象.语法如下:

EXCLUDE=object_type[:name_clause][,….]

object_type用于指定要排除的对象类型,name_clause用于指定要排除的具体对象.EXCLUDE和INCLUDE不能同时使用,示例如下:

expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dup EXCLUDE=VIEW

在EXPDP的帮助文件中, 可以看到存在EXCLUDE和INCLUDE参数, 这两个参数文档中介绍的命令格式存在问题, 正确用法是: 

EXCLUDE=OBJECT_TYPE[:name_clause][,...]

INCLUDE=OBJECT_TYPE[:name_clause][,...]

示例:

expdp   schema=scott exclude=sequence,table:"in('EMP','DEPT')"

impdp   schema=scott include=function,package,procedure,table:"='EMP'"

有了这些还不够, 由于命令中包含了多个特殊字符, 在不同的操作系统下需要通过转义字符才能使上面的命令顺利执行, 

如:

EXCLUDE=TABLE:\"IN('BIGTALE')\"

8. FILESIZE

指定导出文件的最大尺寸,默认为0(表示文件尺寸没有限制).

9. FLASHBACK_SCN

指定导出特定SCN时刻的表数据.语法如下:

FLASHBACK_SCN=scn_value

scn_value用于标识SCN值.FLASHBACK_SCN和FLASHBACK_TIME不能同时使用,示例如下:

expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dmp FLASHBACK_SCN=358523

10. FLASHBACK_TIME

指定导出特定时间点的表数据.语法如下:

FLASHBACK_TIME="TO_TIMESTAMP(time_value)"

示例如下:

expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dmp FLASHBACK_TIME="TO_TIMESTAMP('25-08-2004 14:35:00','DD-MM-YYYY HH24:MI:SS')"

11. FULL

指定数据库模式导出,默认为N.语法如下:

FULL={Y | N}

为Y时,标识执行数据库导出.

12. HELP

指定是否显示EXPDP命令行选项的帮助信息,默认为N. 当设置为Y时,会显示导出选项的帮助信息,示例如下:

expdp help=y

13. INCLUDE

指定导出时要包含的对象类型及相关对象.语法如下:

INCLUDE=object_type[:name_clause][,… ]

示例如下:

expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dmp INCLUDE=trigger

Oracle10g 数据泵导出命令 expdp 使用总结(三)

1.1.2 expdp选项

14. JOB_NAME

指定要导出作用的名称,默认为SYS_XXX.语法如下:

JOB_NAME=jobname_string

示例如下:

expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dmp INCLUDE=trigger JOB_NAME=exp_trigger

后面想临时停止expdp任务时可以按Ctrl+C组合键,退 出当前交互模式,退出之后导出操作不会停止,这不同于Oracle以前的EXP. 以前的EXP,如果退出交互式模式,就会出错终止导出任务. 在 Oracle10g中,由于EXPDP是数据库内部定义的任务,已经与客户端无关. 退出交互之后,会进入export的命令行模式,此时支持 status等查看命令:

Export> status

如果想停止改任务,可以发出stop_job命令:

Export> stop_job

如果有命令行提示: "是否确实要停止此作业([Y]/N):" 或 "Are you sure you wish to stop this job ([yes]/no):", 回答应是yes或者no, 回答是YES以后会退出当前的export界面. 

接下来可以通过命令行再次连接到这个任务:

expdp test/test@acf attach=expfull

通过start_job命令重新启动导出:

Export> start_job

Export> status

15. LOGFILE

指定导出日志文件文件的名称,默认名称为export.log.语法如下:

LOGFILE=[directory_object:]file_name

directory_object用于指定目录对象名称,file_name用于指定导出日志文件名.如果不指定directory_object.导出作用会自动使用DIRECTORY的相应选项值,示例如下:

expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dmp logfile=a.log

16. NETWORK_LINK

指定数据库链名,如果要将远程数据库对象导出到本地例程的转储文件中,必须设置该选项.

expdp中使用连接字符串和network_link的区别:

expdp属于服务端工具,而exp属于客户端工具,expdp生成的文件默认是存放在服务端的,而exp生成的文件是存放在客户端.

expdp username/password@connect_string //对于使用这种格式来说,directory使用源数据库创建的,生成的文件存放在服务端。

如何将生成的文件放在目标数据库而不放在源数据库呢,在expdp中使用network_link. 比如在本机expdp远程服务器的数据库,先在本机创建到服务端的dblink,然后创建directory及授权,然后expdp.

a) 创建到服务端的dblink

conn aa/aacc

create database link link_name connect to bb identified by password using 'connect_string';

b) 建立directory

conn / as sysdba

create or replace directory dir as 'directory';

grant read,write on directory dir to bb;

c) 通过network_link导出

expdp aa/aacc directory=dir network_link=link_name ...

17. NOLOGFILE

该选项用于指定禁止生成导出日志文件,默认值为N.

18. PARALLEL

指定执行导出操作的并行进程个数,默认值为1

19. PARFILE

指定导出参数文件的名称.语法如下:

PARFILE=[directory_path:]file_name

20. QUERY

用于指定过滤导出数据的where条件.语法如下:

QUERY=[schema.][table_name:]query_clause

schema 用于指定方案名,table_name用于指定表名,query_clause用于指定条件限制子句.QUERY选项不能 与 CONNECT=METADATA_ONLY,EXTIMATE_ONLY,TRANSPORT_TABLESPACES等选项同时使用,示例如下:

expdp scott/tiger directory=dump dumpfiel=a.dmp Tables=emp query='WHERE deptno=20'

21. SCHEMAS

该方案用于指定执行方案模式导出,默认为当前用户方案.

22. STATUS

指定显示导出作用进程的详细状态,默认值为0.

23. TABLES

指定表模式导出.语法如下:

TABLES=[schema_name.]table_name[:partition_name][,…]

schema_name用于指定方案名,table_name用于指定导出的表名,partition_name用于指定要导出的分区名.

24. TABLESPACES

指定要导出表空间列表.

25. TRANSPORT_FULL_CHECK

该选项用于指定被搬移表空间和未搬移表空间关联关系的检查方式,默认为N. 

当设置为Y时,导出作用会检查表空间直接的完整关联关系,如果表所在表空间或其索引所在的表空间只有一个表空间被搬移,将显示错误信息. 

当设置为N时,导出作用只检查单端依赖,如果搬移索引所在表空间,但未搬移表所在表空间,将显示出错信息,如果搬移表所在表空间,未搬移索引所在表空间,则不会显示错误信息.

26. TRANSPORT_TABLESPACES

指定执行表空间模式导出.

27. VERSION

指定被导出对象的数据库版本,默认值为COMPATIBLE.语法如下:

VERSION={COMPATIBLE | LATEST | version_string}

为COMPATIBLE时,会根据初始化参数COMPATIBLE生成对象元数据;为LATEST时,会根据数据库的实际版本生成对象元数据.version_string用于指定数据库版本字符串.

实例:

   1、通过DBLINK的方式:表空间不一样

impdp logfile=DUP_MCMDB.LOG network_link=to_crm_7 schemas=MCMDB  REMAP_TABLESPACE=table_space11:table_space12,table_space21:table_space22

   2、通过DBLINK的方式:方案(schemas)不一样

impdp logfile=DUP_MCMDB.LOG network_link=to_crm_7 schemas=MCMDB  remap_schema=MCMDB:MCMDB1

    前言:

   Oracle Database 10g引入了最新的数据泵(Data Dump)技术,使DBA或开发人员可以将数据库元数据(对象定义)和数据快速移动到另一个oracle数据库中。

   数据泵导出导入(EXPDP和IMPDP)的作用

   1,实现逻辑备份和逻辑恢复。

   2,在数据库用户之间移动对象。

   3,在数据库之间移动对象

   4,实现表空间搬移。

   数据泵导出导入与传统导出导入的区别:在10g之前,传统的导出和导入分别使用EXP工具和IMP工具,从10g开始,不仅保留了原有的EXP和IMP工具,还提供了数据泵导出导入工具EXPDP和IMPDP.使用EXPDP和IMPDP时应该注意的事项;EXP和IMP是客户段工具程序,它们既可以在可以客户端使用,也可以在服务端使用。

   EXPDP和IMPDP是服务端的工具程序,他们只能在ORACLE服务端使用,不能在客户端使用IMP只适用于EXP导出文件,不适用于EXPDP导出文件;IMPDP只适用于EXPDP导出文件,而不适用于EXP导出文件。

   数据泵导出包括导出表,导出方案,导出表空间,导出数据库4种方式。

   建目录与赋权:

   SQL>create directory dump_dir as '/u01/dmdir';

   SQL>grant read,write ondirectory to test;

   SQL>select * from dba_directories; ——查看目录

    EXPDP命令行选项

   1. ATTACH

   该选项用于在客户会话与已存在导出作用之间建立关联。语法如下

   ATTACH=[schema_name.]job_name

   Schema_name用于指定方案名,job_name用于指定导出作业名。注意,如果使用ATTACH选项,在命令行除了连接字符串和ATTACH选项外,不能指定任何其他选项,示例如下:Expdp scott/tiger ATTACH=scott.export_job

   2. CONTENT

   该选项用于指定要导出的内容。默认值为ALL

   CONTENT={ALL | DATA_ONLY | METADATA_ONLY}

   当设置CONTENT为ALL 时,将导出对象定义及其所有数据。为DATA_ONLY时,只导出对象数据,为METADATA_ONLY时,只导出对象定义

   Expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dump

   CONTENT=METADATA_ONLY

   3. DIRECTORY

   指定转储文件和日志文件所在的目录

   DIRECTORY=directory_object

   Directory_object用于指定目录对象名称。需要注意,目录对象是使用CREATE DIRECTORY语句建立的对象,而不是OS 目录

   Expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dump

   建立目录:CREATE DIRECTORY dump as 'd:dump';

   查询创建了那些子目录:SELECT * FROMdba_directories;

   4. DUMPFILE

   用于指定转储文件的名称,默认名称为expdat.dmp

   DUMPFILE=[directory_object:]file_name [,…。]

   Directory_object用于指定目录对象名,file_name用于指定转储文件名。需要注意,如果不指定directory_object,导出工具会自动使用DIRECTORY选项指定的目录对象

   Expdp scott/tiger DIRECTORY=dump1 DUMPFILE=dump2:a.dmp

   5. ESTIMATE

   指定估算被导出表所占用磁盘空间分方法。默认值是BLOCKS

   EXTIMATE={BLOCKS | STATISTICS}

   设置为BLOCKS时,oracle会按照目标对象所占用的数据块个数乘以数据块尺寸估算对象占用的空间,设置为STATISTICS时,根据最近统计值估算对象占用空间

   Expdp scott/tiger TABLES=emp ESTIMATE=STATISTICS

   DIRECTORY=dump DUMPFILE=a.dump

   6. EXTIMATE_ONLY

   指定是否只估算导出作业所占用的磁盘空间,默认值为N

   EXTIMATE_ONLY={Y | N}

   设置为Y时,导出作用只估算对象所占用的磁盘空间,而不会执行导出作业,为N时,不仅估算对象所占用的磁盘空间,还会执行导出操作。

   Expdp scott/tiger ESTIMATE_ONLY=y NOLOGFILE=y

   7. EXCLUDE

   该选项用于指定执行操作时释放要排除对象类型或相关对象EXCLUDE=object_type[:name_clause] [,…。] Object_type用于指定要排除的对象类型,name_clause用于指定要排除的具体对象。EXCLUDE和INCLUDE不能同时使用

   Expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dup EXCLUDE=VIEW

   8. FILESIZE

   指定导出文件的最大尺寸,默认为0,(表示文件尺寸没有限制)

   9. FLASHBACK_SCN

   指定导出特定SCN时刻的表数据

   FLASHBACK_SCN=scn_value

   Scn_value用于标识SCN值。FLASHBACK_SCN和FLASHBACK_TIME不能同时使用

   Expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dmp

   FLASHBACK_SCN=358523

  10.FLASHBACK_TIME

   指定导出特定时间点的表数据

   FLASHBACK_TIME="TO_TIMESTAMP(time_value)"

   Expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dmp FLASHBACK_TIME=

   "TO_TIMESTAMP('25-08-2004 14:35:00','DD-MM-YYYY HH24:MI:SS')"

   11. FULL

   指定数据库模式导出,默认为N

   FULL={Y | N}

   为Y时,标识执行数据库导出。

   12. HELP

   指定是否显示EXPDP命令行选项的帮助信息,默认为N当设置为Y时,会显示导出选项的帮助信息。

   Expdp help=y

   13. INCLUDE

   指定导出时要包含的对象类型及相关对象

   INCLUDE = object_type[:name_clause] [,… ]

   14. JOB_NAME

   指定要导出作用的名称,默认为SYS_XXX

   JOB_NAME=jobname_string

   15. LOGFILE

   指定导出日志文件文件的名称,默认名称为export.log

   LOGFILE=[directory_object:]file_name

   Directory_object用于指定目录对象名称,file_name用于指定导出日志文件名。如果不指定directory_object.导出作用会自动使用DIRECTORY的相应选项值。

   Expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dmp logfile=a.log

   16. NETWORK_LINK

   指定数据库链名,如果要将远程数据库对象导出到本地例程的转储文件中,必须设置该选项。

   17. NOLOGFILE

   该选项用于指定禁止生成导出日志文件,默认值为N.

   18. PARALLEL

   指定执行导出操作的并行进程个数,默认值为1

  19.PARFILE

   指定导出参数文件的名称

   PARFILE=[directory_path] file_name

   20. QUERY

   用于指定过滤导出数据的where条件

   QUERY=[schema.] [table_name:] query_clause

   Schema用于指定方案名,table_name用于指定表名,query_clause用于指定条件限制子句。QUERY选项不能与CONNECT= METADATA_ONLY,EXTIMATE_ONLY,TRANSPORT_TABLESPACES等选项同时使用。

   Expdp scott/tiger directory=dump dumpfiel=a.dmp

   Tables=emp query=‘WHERE deptno=20’

   21. SCHEMAS

   该方案用于指定执行方案模式导出,默认为当前用户方案。

   22. STATUS

   指定显示导出作用进程的详细状态,默认值为0

   23. TABLES

   指定表模式导出

   TABLES=[schema_name.]table_name[:partition_name][,…]

   Schema_name用于指定方案名,table_name用于指定导出的表名,partition_name用于指定要导出的分区名。

   24. TABLESPACES

   指定要导出表空间列表

   25. TRANSPORT_FULL_CHECK

   该选项用于指定被搬移表空间和未搬移表空间关联关系的检查方式,默认为N.

   当设置为Y时,导出作用会检查表空间直接的完整关联关系,如果表空间所在表空间或其索引所在的表空间只有一个表空间被搬移,将显示错误信息。当设置为N 时,导出作用只检查单端依赖,如果搬移索引所在表空间,但未搬移表所在表空间,将显示出错信息,如果搬移表所在表空间,未搬移索引所在表空间,则不会显示 错误信息。

   26. TRANSPORT_TABLESPACES

   指定执行表空间模式导出

   27. VERSION指定被导出对象的数据库版本,默认值为COMPATIBLE.

   VERSION={COMPATIBLE | LATEST | version_string}

   为COMPATIBLE时,会根据初始化参数COMPATIBLE生成对象元数据;为LATEST时,会根据数据库的实际版本生成对象元数据。version_string用于指定数据库版本字符串。

    调用EXPDP

   使用EXPDP工具时,其转储文件只能被存放在DIRECTORY对象对应的OS目录中,而不能直接指定转储文件所在的OS目录。因此,使用EXPDP工具时,必须首先建立DIRECTORY对象。并且需要为数据库用户授予使用DIRECTORY对象权限。

   CREATE DIRECTORY dump_dir AS 'D:DUMP';GRANT READ, WIRTE ON DIRECTORY dump_dir TO scott;

   1,导出表

   Expdp scott/tiger DIRECTORY=dump_dir DUMPFILE=tab.dmp TABLES=dept,emp

   2,导出方案

   Expdp scott/tiger DIRECTORY=dump_dir DUMPFILE=schema.dmp SCHEMAS=system,scott

   3.导出表空间

   Expdp system/manager DIRECTORY=dump_dir DUMPFILE=tablespace.dmpTABLESPACES=user01,user02

   4,导出数据库

   Expdp system/manager DIRECTORY=dump_dir DUMPFILE=full.dmp FULL=Y

    使用IMPDP

   IMPDP命令行选项与EXPDP有很多相同的,不同的有:

   1,REMAP_DATAFILE

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

   REMAP_DATAFIEL=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操作写入到SQL脚本中

   SQLFILE=[directory_object:]file_name

   Impdp scott/tiger DIRECTORY=dump DUMPFILE=tab.dmp SQLFILE=a.sql

   7.STREAMS_CONFIGURATION

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

   8,TABLE_EXISTS_ACTION

   该选项用于指定当表已经存在时导入作业要执行的操作,默认为SKIPTABBLE_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’

    调用IMPDP

   1, 导入表

Impdp scott/tiger DIRECTORY=dump_dir DUMPFILE=tab.dmp
TABLES=dept,emp
Impdp system/manage DIRECTORY=dump_dir DUMPFILE=tab.dmp
TABLES=scott.dept,scott.emp REMAP_SCHEMA=SCOTT:SYSTEM

   第一种方法表示将DEPT和EMP表导入到SCOTT方案中,第二种方法表示将DEPT和EMP表导入的SYSTEM方案中。

   注意,如果要将表导入到其他方案中,必须指定REMAP SCHEMA选项。

   2,导入方案

Impdp scott/tiger DIRECTORY=dump_dir DUMPFILE=schema.dmp
SCHEMAS=scott
Impdp system/manager DIRECTORY=dump_dir DUMPFILE=schema.dmp
SCHEMAS=scott REMAP_SCHEMA=scott:system

   3,导入表空间

Impdp system/manager DIRECTORY=dump_dir DUMPFILE=tablespace.dmp
TABLESPACES=user01

   4,导入数据库

Impdp system/manager DIRECTORY=dump_dir DUMPFILE=full.dmp FULL=y

    EXPDP/IMPDP的停止与重启动:

   EXPDP和IMPDP的本质在于,通过API调用,把传统的EXP/IMP类交付式模式的操作,转变成数据库内部的job任务,从而实现了任务的可终止与重启动。

   c:\expdp test/test@acfdirectory=dpdata dumpfile=full.dmp full=y job_name=expfull在执行过程中,可以拿下Ctrl+C组合键,退出当前交互模式,退出之后,导出操作不会停止,这不同于Oracle以前的EXP.以前的EXP,如果退出交互式模式,就会出错终止导出任务。

   在Oracle 10中,由于EXPDP是数据库内部定义的任务,已经与客户端无关。退出交互之后,会进入export的命令行模式,此时支持status等查看命令:

   Export> status

   如果想停止改任务,可以发出stop_job命令

   Export> stop_job

   如果有命令行提示

   是否确实要停止此作业([Y]/N):

   或Are you sure you wish to stop this job ([yes]/no):

   回答应是yes或者no

   接下来可以通过命令行再次连接到这个任务

   c:\expdp test/test@acfattach=expfull

   通过start_job命令重新启动导出

   Export> start_job

   在plsql下查看任务名:

   SQL>select * from DBA_DATAPUMP_JOBS ——查看job

   在plsq下查看对应session:

SQL>select sid, serial#
 2  from v$session s, dba_datapump_sessions d
 3  where s.saddr = d.saddr;

   下列命令在交互模式下有效。

   注: 允许使用缩写命令 说明 (默认)

------------------------------------------------------------------------------

   CONTINUE_CLIENT 返回到记录模式。如果处于空闲状态, 将重新启动作业。

   EXIT_CLIENT 退出客户机会话并使作业处于运行状态。

   HELP 总结交互命令。

   KILL_JOB 分离和删除作业。

   PARALLEL 更改当前作业的活动 worker 的数目。

   PARALLEL=. START_JOB 启动/恢复当前作业。

   START_JOB=SKIP_CURRENT 在开始作业之前将跳过作业停止时执行的任意操作。

   STATUS 在默认值 (0) 将显示可用时的新状态的情况下,要监视的频率 (以秒计) 作业状态。

   STATUS[=interval] STOP_JOB 顺序关闭执行的作业并退出客户机。

   STOP_JOB=IMMEDIATE 将立即关闭数据泵作业。

你可能感兴趣的:(ORACLE数据库迁移,oracle,数据库,java)