阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Oracle使用EXPDP和IMPDP数据泵进行导出导入方法

166次阅读
没有评论

共计 8118 个字符,预计需要花费 21 分钟才能阅读完成。

一、expdp/impdp 和 exp/imp 的区别

1、exp 和 imp 是客户端工具程序,它们既可以在客户端使用,也可以在服务端使用。

2、expdp 和 impdp 是服务端的工具程序,他们只能在 Oracle 服务端使用,不能在客户端使用。

3、imp 只适用于 exp 导出的文件,不适用于 expdp 导出文件;impdp 只适用于 expdp 导出的文件,而不适用于 exp 导出文件。

4、对于 10g 以上的服务器,使用 exp 通常不能导出 0 行数据的空表,而此时必须使用 expdp 导出。

二、expdp 导出步骤

(1)创建逻辑目录:

第一步:在服务器上创建真实的目录;(注意:第三步创建逻辑目录的命令不会在 OS 上创建真正的目录,所以要先在服务器上创建真实的目录。如下图:)

Oracle 使用 EXPDP 和 IMPDP 数据泵进行导出导入方法

第二步:用 sys 管理员登录 sqlplus;

oracle@ypdbtest:/home/oracle/dmp/vechcore>sqlplus

SQL*Plus: Release 11.2.0.4.0 Production on Tue Sep 5 09:20:49 2017

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

Enter user-name: sys as sysdba
Enter password:

Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL>

第三步:创建逻辑目录;

SQL> create directory data_dir as '/home/oracle/dmp/user';

Directory created.

第四步:查看管理员目录,检查是否存在;

SQL> select * from dba_directories;

OWNER                          DIRECTORY_NAME
------------------------------ ------------------------------
DIRECTORY_PATH
--------------------------------------------------------------------------------
SYS                            DATA_DIR
/home/oracle/dmp/user

第五步:用 sys 管理员给你的指定用户赋予在该目录的操作权限。

SQL> grant read,write on directory data_dir to user;

Grant succeeded.

(2)用 expdp 导出 dmp,有五种导出方式:

第一种:“full=y”,全量导出数据库;

expdp user/passwd@orcl dumpfile=expdp.dmp directory=data_dir full=y logfile=expdp.log;

第二种:schemas 按用户导出;

expdp user/passwd@orcl schemas=user dumpfile=expdp.dmp directory=data_dir logfile=expdp.log;

第三种:按表空间导出;

expdp sys/passwd@orcl tablespace=tbs1,tbs2 dumpfile=expdp.dmp directory=data_dir logfile=expdp.log;

第四种:导出表;

expdp user/passwd@orcl tables=table1,table2 dumpfile=expdp.dmp directory=data_dir logfile=expdp.log;

第五种:按查询条件导;

expdp user/passwd@orcl tables=table1='where number=1234' dumpfile=expdp.dmp directory=data_dir logfile=expdp.log;

三、impdp 导入步骤

(1)如果不是同一台服务器,需要先将上面的 dmp 文件下载到目标服务器上,具体命令参照:http://www.cnblogs.com/promise-x/p/7452972.html

(2)参照“expdp 导出步骤”里的前三步,建立逻辑目录;

(3)用 impdp 命令导入,对应五种方式:

第一种:“full=y”,全量导入数据库;

impdp user/passwd directory=data_dir dumpfile=expdp.dmp full=y;

第二种:同名用户导入,从用户 A 导入到用户 A;

impdp A/passwd schemas=A directory=data_dir dumpfile=expdp.dmp logfile=impdp.log;

第三种:①从 A 用户中把表 table1 和 table2 导入到 B 用户中;

impdp B/passwdtables=A.table1,A.table2 remap_schema=A:B directory=data_dir dumpfile=expdp.dmp logfile=impdp.log;

②将表空间 TBS01、TBS02、TBS03 导入到表空间 A_TBS,将用户 B 的数据导入到 A,并生成新的 oid 防止冲突;

impdp A/passwdremap_tablespace=TBS01:A_TBS,TBS02:A_TBS,TBS03:A_TBS remap_schema=B:A FULL=Y transform=oid:n 
directory=data_dir dumpfile=expdp.dmp logfile=impdp.log

第四种:导入表空间;

impdp sys/passwd tablespaces=tbs1 directory=data_dir dumpfile=expdp.dmp logfile=impdp.log;

第五种:追加数据;

impdp sys/passwd directory=data_dir dumpfile=expdp.dmp schemas=system table_exists_action=replace logfile=impdp.log; 
--table_exists_action: 导入对象已存在时执行的操作。有效关键字:SKIP,APPEND,REPLACE 和 TRUNCATE

 

四、expdp 关键字与命令


(1)关键字   说明 (默认)


 ATTACH 连接到现有作业, 例如 ATTACH [= 作业名]。

 COMPRESSION   减小转储文件内容的大小, 其中有效关键字  值为: ALL, (METADATA_ONLY), DATA_ONLY 和 NONE。

 CONTENT   指定要卸载的数据, 其中有效关键字  值为: (ALL), DATA_ONLY 和 METADATA_ONLY。

 DATA_OPTIONS     数据层标记, 其中唯一有效的值为: 使用 CLOB 格式的 XML_CLOBS-write XML 数据类型。

 DIRECTORY   供转储文件和日志文件使用的目录对象,即逻辑目录。

 DUMPFILE 目标转储文件 (expdp.dmp) 的列表, 例如 DUMPFILE=expdp1.dmp, expdp2.dmp。

 ENCRYPTION   加密部分或全部转储文件, 其中有效关键字值为: ALL, DATA_ONLY, METADATA_ONLY,ENCRYPTED_COLUMNS_ONLY 或 NONE。

 ENCRYPTION_ALGORITHM 指定应如何完成加密, 其中有效关键字值为: (AES128), AES192 和 AES256。

 ENCRYPTION_MODE 生成加密密钥的方法, 其中有效关键字值为: DUAL, PASSWORD 和 (TRANSPARENT)。

 ENCRYPTION_PASSWORD 用于创建加密列数据的口令关键字。

 ESTIMATE 计算作业估计值, 其中有效关键字值为: (BLOCKS) 和 STATISTICS。

 ESTIMATE_ONLY   在不执行导出的情况下计算作业估计值。

 EXCLUDE 排除特定的对象类型, 例如 EXCLUDE=TABLE:EMP。例:EXCLUDE=[object_type]:[name_clause],[object_type]:[name_clause]。

 FILESIZE   以字节为单位指定每个转储文件的大小。

 FLASHBACK_SCN   用于将会话快照设置回以前状态的 SCN。— 指定导出特定 SCN 时刻的表数据。

 FLASHBACK_TIME 用于获取最接近指定时间的 SCN 的时间。– 定导出特定时间点的表数据,注意 FLASHBACK_SCN 和 FLASHBACK_TIME 不能同时使用。

 FULL   导出整个数据库 (N)。

 HELP   显示帮助消息 (N)。

 INCLUDE   包括特定的对象类型, 例如 INCLUDE=TABLE_DATA。

 JOB_NAME   要创建的导出作业的名称。

 LOGFILE   日志文件名 (export.log)。

 NETWORK_LINK   链接到源系统的远程数据库的名称。

 NOLOGFILE 不写入日志文件 (N)。

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

 PARFILE   指定参数文件。

 QUERY 用于导出表的子集的谓词子句。–QUERY = [schema.][table_name:] query_clause。

 REMAP_DATA     指定数据转换函数, 例如 REMAP_DATA=EMP.EMPNO:REMAPPKG.EMPNO。

 REUSE_DUMPFILES 覆盖目标转储文件 (如果文件存在) (N)。

 SAMPLE   要导出的数据的百分比。

 SCHEMAS   要导出的方案的列表 (登录方案)。

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

 TABLES   标识要导出的表的列表 – 只有一个方案。–[schema_name.]table_name[:partition_name][,…]

 TABLESPACES   标识要导出的表空间的列表。

 TRANSPORTABLE   指定是否可以使用可传输方法, 其中有效关键字值为: ALWAYS, (NEVER)。

 TRANSPORT_FULL_CHECK 验证所有表的存储段 (N)。

 TRANSPORT_TABLESPACES   要从中卸载元数据的表空间的列表。

 VERSION 要导出的对象的版本, 其中有效关键字为:(COMPATIBLE), LATEST 或任何有效的数据库版本。


(2)命令 说明


 ADD_FILE 向转储文件集中添加转储文件。

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

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

 FILESIZE 后续 ADD_FILE 命令的默认文件大小 (字节)。

 HELP 总结交互命令。

 KILL_JOB 分离和删除作业。

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

 _DUMPFILES 覆盖目标转储文件 (如果文件存在) (N)。

 START_JOB   启动 / 恢复当前作业。

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

 STOP_JOB 顺序关闭执行的作业并退出客户机。STOP_JOB=IMMEDIATE 将立即关闭数据泵作业。


 

五、impdp 关键字与命令


(1)关键字 说明 (默认)


ATTACH 连接到现有作业, 例如 ATTACH [= 作业名]。

CONTENT   指定要卸载的数据, 其中有效关键字  值为: (ALL), DATA_ONLY 和 METADATA_ONLY。

DATA_OPTIONS     数据层标记, 其中唯一有效的值为:SKIP_CONSTRAINT_ERRORS- 约束条件错误不严重。

DIRECTORY 供转储文件, 日志文件和 sql 文件使用的目录对象,即逻辑目录。

DUMPFILE 要从 (expdp.dmp) 中导入的转储文件的列表, 例如 DUMPFILE=expdp1.dmp, expdp2.dmp。

 ENCRYPTION_PASSWORD 用于访问加密列数据的口令关键字。此参数对网络导入作业无效。

 ESTIMATE 计算作业估计值, 其中有效关键字为:(BLOCKS)和 STATISTICS。

 EXCLUDE 排除特定的对象类型, 例如 EXCLUDE=TABLE:EMP。

 FLASHBACK_SCN 用于将会话快照设置回以前状态的 SCN。

 FLASHBACK_TIME 用于获取最接近指定时间的 SCN 的时间。

 FULL 从源导入全部对象(Y)。

 HELP 显示帮助消息(N)。

 INCLUDE  包括特定的对象类型, 例如 INCLUDE=TABLE_DATA。

 JOB_NAME 要创建的导入作业的名称。

 LOGFILE   日志文件名(import.log)。

 NETWORK_LINK 链接到源系统的远程数据库的名称。

 NOLOGFILE 不写入日志文件。

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

 PARFILE   指定参数文件。

 PARTITION_OPTIONS  指定应如何转换分区, 其中有效关键字为:DEPARTITION,MERGE 和(NONE)。

 QUERY 用于导入表的子集的谓词子句。

 REMAP_DATA 指定数据转换函数, 例如 REMAP_DATA=EMP.EMPNO:REMAPPKG.EMPNO。

 REMAP_DATAFILE 在所有 DDL 语句中重新定义数据文件引用。

 REMAP_SCHEMA  将一个方案中的对象加载到另一个方案。

 REMAP_TABLE   表名重新映射到另一个表, 例如 REMAP_TABLE=EMP.EMPNO:REMAPPKG.EMPNO。

 REMAP_TABLESPACE 将表空间对象重新映射到另一个表空间。

 REUSE_DATAFILES 如果表空间已存在, 则将其初始化 (N)。

 SCHEMAS   要导入的方案的列表。

 SKIP_UNUSABLE_INDEXES   跳过设置为无用索引状态的索引。

 SQLFILE   将所有的 SQL DDL 写入指定的文件。

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

 STREAMS_CONFIGURATION   启用流元数据的加载。

 TABLE_EXISTS_ACTION 导入对象已存在时执行的操作。有效关键字:(SKIP),APPEND,REPLACE 和 TRUNCATE。

 TABLES   标识要导入的表的列表。

 TABLESPACES 标识要导入的表空间的列表。

 TRANSFORM 要应用于适用对象的元数据转换。有效转换关键字为:SEGMENT_ATTRIBUTES,STORAGE,OID 和 PCTSPACE。

 TRANSPORTABLE   用于选择可传输数据移动的选项。有效关键字为: ALWAYS 和 (NEVER)。仅在 NETWORK_LINK 模式导入操作中有效。

 TRANSPORT_DATAFILES 按可传输模式导入的数据文件的列表。

 TRANSPORT_FULL_CHECK 验证所有表的存储段 (N)。

 TRANSPORT_TABLESPACES 要从中加载元数据的表空间的列表。仅在 NETWORK_LINK 模式导入操作中有效。

  VERSION   要导出的对象的版本, 其中有效关键字为:(COMPATIBLE), LATEST 或任何有效的数据库版本。仅对 NETWORK_LINK 和 SQLFILE 有效。


(2)命令 说明


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

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

 HELP   总结交互命令。

 KILL_JOB   分离和删除作业。

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

 START_JOB   启动 / 恢复当前作业。START_JOB=SKIP_CURRENT 在开始作业之前将跳过作业停止时执行的任意操作。

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

 STOP_JOB 顺序关闭执行的作业并退出客户机。STOP_JOB=IMMEDIATE 将立即关闭数据泵作业。 

更多 Oracle 相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-09/146764.htm

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-22发表,共计8118字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中