最近发现使用直接导出模式direct=y exp比传统模式导出快很多,而且似乎也不会遇见什么bug.(至今没有遇见过)
oracle提供2种模式导出表数据,传统模式CONVENTIONAL PATH和直接模式DIRECT PATH,有direct指定。
CONVENTIONAL PATH EXPORT 比较DIRECT PATH EXPORT
====================================================
差异
1. Conventional path Export.
-------------------------
传统导出模式使用SQL SELECT语句抽取表数据。将数据从磁盘中读入到buffer cache缓冲区中,并应用SQL表达式,将纪录返回给导出客户端,然后写到导出文件。
2. Direct path Export.
-------------------
直接导出模式,数据直接从磁盘中读取到导出session的UGA中,跳过了SQL命令处理层。避免了不必要的数据转换, 然后将纪录返回给导出客户端,然后写到到处文件 跳过了SQL命令处理层表示DIRECT导出不支持QUERY选项。
性能
1. Direct Export 比Conventional Export要快很多。在实际应用中,如果直接模式导出需要时间N,传统模式导出则需要2*N到3*N之间。
2. 当Direct Export 的时候设置大的RECORDLENGTH(length of IO record) 参数可以加快导出。最大64k,
exp userid=system/manager full=y direct=y recordlength=65535
file=exp_full.dmp log=exp_full.log
imp userid=system/manager full=y recordlength=65535
file=exp_full.dmp log=imp_full.log
3. Direct 模式导出并不影响导入数据的速度;导入数据与传统模式花费时间一样。
限制
------------
1. 导出表空间必须使用传统模式。
2. 含有LOB对象的表不支持直接导出模式。
3. 直接导出不支持QUERY.
4. 直接导出模式使用RECORDLENGTH设置一次可以导出数据的量,传统模式使用buffer设置.
5. 低版本直接导出模式要求导出客户端和数据库字符集设置一致。
直接导出模式bug比传统模式要多,但由于其导出数据在性能上的优势,仍然要多加使用。
分享到:
相关推荐
- **EXP/IMP (客户端方式)**: 这是最传统的数据导出导入方式,适用于较小的数据集。 - **导出命令示例**: - 导出整个数据库: ```sql EXP username/password@database file=export_file.dmp buffer=204800 ...
- **direct=direct`或`direct=conventional`:选择导出方式(直接或传统)。 #### 四、注意事项 1. **权限问题**:执行导出操作通常需要具有足够的权限,例如`DBA`角色或其他特定权限。 2. **资源限制**:大型...
### Oracle导入/导出数据详解 #### 一、Oracle导入实用程序概述 Oracle的导入实用程序(Import Utility),简称IMP,是一种强大的工具,用于将数据从一个操作系统文件中加载到Oracle数据库中。IMP的主要功能是从...
本文将详细介绍如何利用`expdp`和`impdp`命令来完成Oracle数据库的数据导入导出。 #### 一、Oracle数据库导出操作 Oracle提供了多种导出数据的方法,其中`expdp`是最常用的一种。它能够导出整个数据库、单个表空间...
- **direct=N**: 是否采用直接路径模式,默认为N。 - **triggers=Y**: 是否导出发起器,默认为Y。 - **feedback=每x行显示一次**: 显示导出进度,默认为0不显示。 - **filesize=文件大小**: 单个导出文件的最大...
- `direct=y`:使用快速导出方式。 - `recordlength=65535`:设置记录长度。 ##### 3.6 有条件的导出 示例: ``` exp system/ckdb5@ckdb5 tables = (cp962008.misywt40_1) file=t40_96.dmp log=t40_96_exp.log ...
本篇文章将深入探讨Oracle中的"exp"和"imp"命令,它们是Oracle传统数据泵工具的一部分,用于实现数据的导出和导入。 1. **Oracle数据导出(exp)** - **exp命令简介**:exp是Oracle数据库提供的一个实用程序,用于...
- **1.1.3 直接导出(比默认导出速度快,适用于大数据量)** - **命令格式**: ``` exp userid=<用户名>/<密码>@<数据库实例> tables=(<表名1>,<表名2>,...) file=<文件路径> direct=y ``` - **示例**: ``` ...
通过使用Oracle提供的导入(Import)和导出(Export)工具,我们可以有效地进行数据迁移、备份以及恢复等操作。本文将详细介绍Oracle导入导出命令的相关知识点,帮助读者更好地理解和掌握这些实用技巧。 #### 导入...
- `DIRECT`:指定是否使用直接路径导出,`N` 表示不使用直接路径。 - `TRIGGERS`:指定是否导出触发器,`Y` 表示导出触发器。 - `FEEDBACK`:指定每导出多少行显示一次进度,`0` 表示不显示进度。 - `OLSIZE`:...
`direct=y`表示使用直接路径导出,可以提高性能。 ##### 2. `OWNER` 和 `TABLES` 参数 - **功能**:用于指定导出的对象所有者或者特定的表。 - **示例**: ```shell exp userid=gwm/gwm file=/test.dmp log=test...
Oracle 数据备份与还原 Oracle 数据库备份与还原是指将 Oracle 数据库中的数据备份到外部文件中,并在需要时将其还原回数据库中的过程。下面是 Oracle 数据备份与还原的相关知识点: 1. 基本概念 * 数据备份:指...
在Oracle数据库管理过程中,经常会遇到数据迁移的需求,其中一个常见的操作就是使用`exp`命令将表数据导出为一个文件,再使用`imp`命令将这个文件中的数据导入到另一个数据库或用户下。然而,在实际操作中可能会遇到...
Oracle 提供了多种方式进行数据导出,其中最常用的是 `expdp` 和 `exp` 命令行工具。 **命令示例:** - 使用 `exp` 命令进行全库导出: ``` exp QZXGXT/QZXGXT@190 file=f:\QZXGXT20081106.dmp full=y ``` ...
Oracle的`Imp`和`Exp`是用于数据库数据导入导出的强大工具,尤其在处理小型数据库或进行特定数据迁移时表现出色。尽管它们在大数据量处理上可能不如RMAN或第三方工具高效,但在特定场景下,如表空间迁移、表数据提取...
Oracle的IMP(Import)和EXP(Export)命令是数据库管理员在Oracle环境中常用的数据导入导出工具。它们分别用于将数据从一个数据库导出到文件,然后将这些数据从文件导入到另一个数据库,或者同一个数据库的不同表...
通过指定`direct=y`参数,可以启用直接路径导出,这对于大容量数据的导出非常有帮助。 #### 五、数据导入(Import) 完成数据导出后,下一步是在目标系统上进行数据导入。同样使用Oracle的`IMPDP`或`IMP`工具完成...