数据泵(DATA PUMP)是一种在数据库之间、数据库与操做系统之间,高速传输数据的技术(10g推出)。sql
逻辑备份是对数据库对象(如用户、表、存储过程等)利用EXPORT等工具进行导出数据库
物理备份是转储ORACLE物理文件(如数据文件、控制文件、归档日志文件等)
物理备份旨在彻底恢复整个数据库,要求彻底相同的备份环境和恢复环境
逻辑备份旨在备份数据自己,可移植性强,可是备份和恢复速度低下,大型业务系统通常不用网络
CREATE DIRECTORY 目录名(dump_dir) as '绝对路径';oracle
GRANT read,write on directory 目录名 to 导入导出用户;函数
SELECT * FROM DBA_DIRECTORIES; 查询全部已建立的目录 DROP directory 目录名; 删除目录
第一种:全量导出数据库:
expdp 用户名/密码@orcl dumpfile=导出文件名.dmp directory=目录名 full=y logfile=日志名.log;(与dmp一个目录)工具
第二种:按用户导出:
expdp 用户名/密码@orcl schemas=用户 dumpfile=导出文件名.dmp directory=目录名 logfile=日志名.log;加密
第三种:按表空间导出:
expdp 用户名/密码@orcl tablespace=表空间名 dumpfile=导出文件名.dmp directory=目录名 logfile=日志名.log;spa
第四种:按表导出:
expdp 用户名/密码@orcl tables=表名 dumpfile=导出文件名.dmp directory=目录名 logfile=日志名.log;
导出表结构
expdp 用户名/密码@orcl directory=目录名 dumpfile=导出文件名.dmp content=metadata_only tables=(a,b)
metadata_only表明只导出表结构操作系统
第五种:按查询条件导:
expdp 用户名/密码@orcl tables=表名='where 条件=值' dumpfile=导出文件名.dmp directory=目录名 logfile=日志名.log;日志
第一种:全量导入数据库;
impdp 用户名/密码 directory=data_dir dumpfile=expdp.dmp full=y;
第二种:按名用户导入,从源用户名1导入到目标用户名2;
impdp 用户名/密码 REMAP_SCHEMA=[源用户名1]:[目标用户名2] directory=data_dir dumpfile=expdp.dmp logfile=impdp.log;
第三种:
a.从A用户中把表table1和table2导入到B用户中;
impdp 用户名/密码 tables=A.table1,A.table2 REMAP_SCHEMA=A:B directory=data_dir dumpfile=expdp.dmp logfile=impdp.log;
b.将表空间TBS0一、TBS0二、TBS03导入到表空间A_TBS,将用户B的数据导入到A,并生成新的oid防止冲突;
impdp 用户名/密码 remap_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
c.导入表结构
第四种:导入表空间;
impdp 用户名/密码 tablespaces=tbs1 directory=data_dir dumpfile=expdp.dmp logfile=impdp.log;
第五种:追加数据;
impdp 用户名/密码 directory=data_dir dumpfile=expdp.dmp schemas=system table_exists_action=replace logfile=impdp.log;
--table_exists_action:导入对象已存在时执行的操做。有效关键字:SKIP,APPEND,REPLACE和TRUNCATE
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 或任何有效的数据库版本。
ADD_FILE 向转储文件集中添加转储文件。
CONTINUE_CLIENT 返回到记录模式。若是处于空闲状态, 将从新启动做业。
EXIT_CLIENT 退出客户机会话并使做业处于运行状态。
FILESIZE 后续 ADD_FILE 命令的默认文件大小 (字节)。
HELP 总结交互命令。
KILL_JOB 分离和删除做业。
PARALLEL 更改当前做业的活动 worker 的数目。PARALLEL=
_DUMPFILES 覆盖目标转储文件 (若是文件存在) (N)。
START_JOB 启动/恢复当前做业。
STATUS 在默认值 (0) 将显示可用时的新状态的状况下,要监视的频率 (以秒计) 做业状态。STATUS[=interval]。
STOP_JOB 顺序关闭执行的做业并退出客户机。STOP_JOB=IMMEDIATE 将当即关闭数据泵做业。
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 有效。
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 将当即关闭数据泵做业。