Oracle 数据泵expdq,impdq[通俗易懂]

Oracle 数据泵expdq,impdq[通俗易懂]使用数据泵技术实现逻辑备份 数据泵概述 数据泵(DATA PUMP)是一种在数据库之间、数据库与操作系统之间,高速传输数据的技术(10g推出)。 逻辑备份概述 逻辑备份是对数据库对象(如用户、表、存储

Oracle 数据泵expdq,impdq

使用数据泵技术实现逻辑备份

数据泵概述

数据泵(DATA PUMP)是一种在数据库之间、数据库与操作系统之间,高速传输数据的技术(10g推出)。

逻辑备份概述

逻辑备份是对数据库对象(如用户、表、存储过程等)利用EXPORT等工具进行导出

物理备份对比

物理备份是转储ORACLE物理文件(如数据文件、控制文件、归档日志文件等)
物理备份旨在完全恢复整个数据库,要求完全相同的备份环境和恢复环境
逻辑备份旨在备份数据本身,可移植性强,但是备份和恢复速度低下,大型业务系统一般不用

操作步骤

1.创建目录对象(在哪导入,导出到哪)

CREATE DIRECTORY 目录名(dump_dir) as “绝对路径”;

2.dump_dir目录授予

GRANT read,write on directory 目录名 to 导入导出用户;

SELECT * FROM DBA_DIRECTORIES; 查询所有已创建的目录
DROP directory 目录名; 删除目录

代码100分

3.expdq导出(EXPDP和IMPDP是Oracle服务端的工具,退出sqlplus)

第一种:全量导出数据库:
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;

第四种:按表导出:
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;

4.impdq(退出sqlplus)

第一种:全量导入数据库;
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.将表空间TBS01、TBS02、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

5.参数

1.expdb

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 将立即关闭数据泵作业。

2.impdq

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 将立即关闭数据泵作业。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/10277.html

(0)
上一篇 2022-12-30
下一篇 2022-12-30

相关推荐

  • oracle 11G rac 环境下修改IP地址「建议收藏」

    oracle 11G rac 环境下修改IP地址「建议收藏」本次实验基于11gR2 RAC做如下维护实验,以便需要在生产环境中做相应的更改时进行参考: 1、更改私有IP网段。 2、更改PUBLIC IP、VIP网段及地址,从192.168.133.10x网段…

    2023-01-28
    147
  • Python Time库基础教程

    Python Time库基础教程时间是人类不可逆转的流逝,而时间的计算处理也是软件开发中不可或缺的部分。Python语言中的Time库提供了一组简单而又强大的操作时间的函数。

    2024-05-24
    82
  • NodeJS Sequelize 生成数据库表[通俗易懂]

    NodeJS Sequelize 生成数据库表[通俗易懂] 1.创建一个数据库 2.使用 sequelize cli 初始化 项目的数据库配置信息 ‘npx sequelize init’ 3.生成模型文件 1.migrate文件 2.model文件…

    2023-03-19
    154
  • 字节跳动业务体系_字节跳动董事长

    字节跳动业务体系_字节跳动董事长字节的 DataCatalog 系统,在 2021 年进行过大规模重构,新版本的存储层基于 Apache Atlas 实现。迁移过程中,我们遇到了比较多的性能问题。本文以 Data Catalog 系

    2023-05-21
    155
  • 使用redis实现消息队列_redis作为消息队列

    使用redis实现消息队列_redis作为消息队列  众所周知,消息队列是应用系统中重要的组件,主要解决应用解耦,异步消息,流量削锋等问题,实现高性能,高可用,可伸缩和最终一致性架构。目前使用较多的消息队列有 ActiveMQ,RabbitMQ,Z…

    2023-03-09
    135
  • Python工程师首选编程字体推荐

    Python工程师首选编程字体推荐相信很多Python工程师在编写代码的时候都遇到过字体过小、不清晰的问题,这会影响开发效率、阅读体验甚至眼部健康。因此,在选择适合自己的编程字体方面要格外重视。本文将从多个方面推荐几款适合Python编程的字体,方便Python工程师进行选择。

    2024-04-06
    90
  • 如何彻底卸载Python

    如何彻底卸载PythonPython是一种很流行的编程语言,被广泛应用于软件开发、数据分析、机器学习等领域。然而,由于各种原因,有时候我们需要彻底卸载Python。本文将从多个方面为大家详细介绍如何彻底卸载Python。

    2024-05-23
    61
  • mysql 8.0设置collation_connection「建议收藏」

    mysql 8.0设置collation_connection「建议收藏」设置全局 set global collation_connection = utf8mb4_general_ci 设置会话级别 1.配置文件方式,给每个新的连接配置 [mysql

    2023-06-08
    122

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注