传统路径导出 VS 直接路径导出(oracle exp direct=y)
Oracle 传统的Export与Import依旧被保留到11g,而且9i与10g有很多依旧使用Export与Import方式进行备份与恢复的企业。从Oracle 7.3开始,传统的exp导出程序提供两种的导出路径方式,一个是传统路径导出(Conventional Path Export),一个是直接路径导出(Direct Path Export)。本文即是因最近客户的传统导入导出性能问题对此进行描述。
1、两者的差异
a、 Conventional path Export
传统路径模式使用SQL SELECT语句抽取表数据。数据从磁盘读入到buffer cache缓冲区中,行被转移到评估缓冲区。
在此之后根据SQL表达式,将记录返回给导出客户端,然后写入到dump文件。
b、Direct path Export
直接导出模式,数据直接从磁盘中读取到导出session的PGA中,行被直接转移到导出session的私有缓冲区,从而跳过SQL命令处理层。
避免了不必要的数据转换。最后记录返回给导出客户端,写到dump文件。
2、性能问题
a、直接路径导出方式比传统路径方式具有更优的性能,速度更快,因为绕过了SQL命令处理部分。
b、直接路径导出方式支持RECORDLENGTH参数(最大为64k),该参数值通常建议设置为系统I/O或者DB_BLOCK_SIZE的整数倍
c、影响直接路径导出的具体因素(DB_BLOCK_SIZE,列的类型,I/O性能,即数据文件所在的磁盘驱动器是否单独于dump文件所在的磁盘驱动器)
d、无论是直接路径导出还是传统路径导出产生的dump,在使用imp方式导入时,会耗用相同的时间
3、简单示例
> exp system/manager FILE=exp_full.dmp LOG=exp_full.log \
FULL=y DIRECT=y RECORDLENGTH=65535
> imp system/manager FILE=exp_full.dmp LOG=imp_full.log \
FULL=y RECORDLENGTH=65535
4、直接路径导出的限制
a、直接路径导出不支持交互模式
b、不支持表空间传输模式(即TRANSPORT_TABLESPACES=Y不被支持),支持的是FULL,OWNER,TABLES导出方式
c、不支持QUERY查询方式,如exp scott/tiger TABLES=emp QUERY=\"WHERE job=\'SALESMAN\' \" 不被支持
d、直接路径导出使用RECORDLENGTH设置一次可以导出数据的量,取代传统路径使用buffer的设置
e、直接路径导出要求NLS_LANG环境参数等于数据库字符集,负责收到EXP-41警告及EXP-0终止错误
5、演示两种方式性能差异
- a、传统路径导出与直接路径导出性能对比
- #下面直接进行日志对比
- robin@SZDB:/u02/database/SYBO2SZ/BNR/dump> more dump1.log
- Start to dump at Fri Jun 21 15:32:57 CST 2013 ....
- Connected to: Oracle Database 10g Release 10.2.0.3.0 - 64bit Production
- Export done in US7ASCII character set and UTF8 NCHAR character set
- server uses UTF8 character set (possible charset conversion)
- About to export specified tables via Conventional Path ...#这个地方是关键描述信息,指明了导出方式
- . . exporting table TRADE_CLIENT_TBL_ARC 1395093 rows exported #数据139万行
- Export terminated successfully with warnings.
- End dump at Fri Jun 21 15:34:31 CST 2013 . #耗用时间15:34:31-15:32:57=不到2min
- # Author : Robinson
- # Blog : http://blog.csdn.net/robinson_0612
- robin@SZDB:/u02/database/SYBO2SZ/BNR/dump> more dump2.log
- Start to dump at Fri Jun 21 15:37:13 CST 2013 ....
- Connected to: Oracle Database 10g Release 10.2.0.3.0 - 64bit Production
- Export done in US7ASCII character set and UTF8 NCHAR character set
- server uses UTF8 character set (possible charset conversion)
- About to export specified tables via Direct Path ...#这个地方是关键描述信息,指明了导出方式
- . . exporting table TRADE_CLIENT_TBL_ARC 1395093 rows exported
- Export terminated successfully with warnings.
- End dump at Fri Jun 21 15:37:30 CST 2013 . #耗用时间15:37:30-15:37:13 =17s
- b、演示对lob数据类型的支持
- scott@SYBO2SZ> create table scott.testtab2 (nr number, txt clob);
- Table created.
- scott@SYBO2SZ> declare
- 2 x varchar2(50);
- 3 begin
- 4 for i in 1..5000 loop
- 5 x := 'This is a line with the number: ' || i;
- 6 insert into scott.testtab2 values(i,x);
- 7 commit;
- 8 end loop;
- 9 end;
- 10 /
- PL/SQL procedure successfully completed.
- scott@SYBO2SZ> select count(*) from testtab2;
- COUNT(*)
- ----------
- 5000
- robin@SZDB:/u02/database/SYBO2SZ/BNR/dump> exp scott/tiger file=exp_testtab2.dmp tables=scott.testtab2 direct=y
- Export: Release 10.2.0.3.0 - Production on Fri Jun 21 11:56:37 2013
- Copyright (c) 1982, 2005, Oracle. All rights reserved.
- Connected to: Oracle Database 10g Release 10.2.0.3.0 - 64bit Production
- Export done in US7ASCII character set and UTF8 NCHAR character set
- server uses UTF8 character set (possible charset conversion)
- About to export specified tables via Direct Path ...
- Table TESTTAB2 will be exported in conventional path.
- . . exporting table TESTTAB2 5000 rows exported
- Export terminated successfully without warnings.
传统路径导出 VS 直接路径导出(oracle exp direct=y)的更多相关文章
- oracle exp direct 执行机制
使用直接导出模式 direct=y exp 比传统模式导出快一倍 oracle提供2种模式导出表数据,传统模式CONVENTIONAL PATH和直接模式DIRECT PATH,有direct指定. ...
- oracle exp(expdp)数据迁移(生产环境,进行数据对比校验)
前言:客户需要迁移XX 库 ZJJJ用户(迁移到其他数据库),由于业务复杂,客户都弄不清楚里面有哪些业务系统,为保持数据一致性,需要停止业务软件,中间件,杀掉oracle进程. 一.迁移数据倒出部分= ...
- Oracle exp/imp数据导入导出工具基本用法
一.获取帮助 exp/imp help=y 二.数据导出 1.将数据库完全导出,设置full选项exp system/manager@orcl file=d:\db.dmp full=y 2.导出数据 ...
- 案例情景--在一次Oracle 数据库导出时 EXP-00008;ORA-00904:EXP-00000: oracle不同版本导入导出规则
案例情景--在一次Oracle 数据库导出时: C:\Documents and Settings\Administrator>exp lsxy/lsxy@lsxy_db file=E:\lsx ...
- Oracle exp,imp,expdp,impdp数据导入导出
一.导出模式(三种模式)及命令格式 1. 全库模式 exp 用户名/密码@网络服务名 full=y file=路径\文件名.dmp log=路径\文件名.log 2. 用户模式(一般情况下采用此模式) ...
- oracle EXP导出一张表时使用query参数指定where条件
oracle exp 导出一个表的部分内容,使用query参数可加上SQL的where条件进行过滤 注意:如果需要使用到日期字符串格式等单引号,需要使用双引号将where条件括起来,而且双引号要用\做 ...
- oracle exp、imp实现导出导入
一.说明 oracle 的exp/imp命令用于实现对数据库的导出/导入操作; exp命令用于把数据从远程数据库服务器导出至本地,生成dmp文件; imp命令用于把本地的数据库dmp文件从本地导 ...
- oracle exp 无法导出空表
oracle exp 无法导出空表 select 'alter table '|| a.table_name ||' allocate extent;' from user_tables a wh ...
- JXLS导出Excel(模板导出)
1.导包 在pom.xml中加入依赖如下: <dependency> <groupId>org.jxls</groupId> <artifactId>j ...
随机推荐
- 关于GDI+
原文链接地址:http://www.2cto.com/kf/201107/97283.html 一 介绍 其实本人对GDI+不能算是专家,只是在几个小项目中应用了一些而已, 算是入门了. 刚好最近有点 ...
- BZOJ2753 [SCOI2012]滑雪与时间胶囊 【kruskal】
题目链接 BZOJ2753 题解 完了我连\(kruskal\)裸题都做不出来了.. 题目是求最小树形图,即有向图最小生成树 我们不能直接上\(kruskal\),而要保证先加入前面的点, 所以我们排 ...
- [poj 3436]最大流+输出结果每条边流量
题目链接:http://poj.org/problem?id=3436 大力套kuangbin板过了orz #include<cstdio> #include<cstring> ...
- java程序在centos7里面开机自启动
1.我们先来个简单的start,status,stop程序: [root@localhost ~]# cat /home/tomcat/jarservice.sh #!/bin/bashCU_PID= ...
- 迅雷Bolt图像拉伸不清晰的解决办法
迅雷Bolt库中的图像拉伸的效果锯齿比较严重,常见的导致锯齿的情况: 1.在使用ImageObject时,drawmode为1拉伸模式下: 2.使用Bitmap类的Stretch函数拉伸图像: 虽然I ...
- (转)Notepad++
包括notepad++的详细的安装过程,插件使用说明,技巧…… crifan http://www.crifan.com/files/doc/docbook/rec_soft_npp/release/ ...
- MySQL远程访问权限 允许远程连接
1 首先cd / 到根目录,打开mysql控制台 登录数据库 mysql -u root -p 2.授权远程连接 mysql> use mysql; Database changed mysq ...
- Asp.Net Core 基于QuartzNet任务管理系统(这是一篇用来水的随笔)
之前一直想搞个后台任务管理系统,零零散散的搞到现在,也算完成了. 废话不多说,进入正题. github地址:https://github.com/YANGKANG01/QuartzNetJob 一.项 ...
- springMvc4+hibernate4+activiti5.15(Maven)
首先创建activiti表 方式1.用代码创建 package createtable; import org.activiti.engine.ProcessEngineConfiguration; ...
- Javadoc注释的用法
Javadoc注释的用法 相关阅读:http://blog.163.com/hui_san/blog/static/5710286720104191100389/ Java 文档// 注释一行/* ...