关于exp/imp的总结学习(r4笔记第26天)

关于exp/imp,是很常用的数据导出导入工具,在10g开始推出的数据泵datapump相当于是exp/imp的补充和升级版本。在后续章节再做一个总结。 exp/imp的使用相对比较简单,通常用做在不同的数据库或者环境之间转移数据,即使数据库位于不同的平台,也可以通过统一的接口来做数据的导入导出工作。 使用方法可以通过exp -help,imp -help来得到一个简单的帮助说明。

USERID must be the first parameter on the command line.Keyword Description (Default) Keyword Description (Default)--------------------------------------------------------------------------USERID username/password FULL export entire file (N)BUFFER size of data buffer OWNER list of owner usernamesFILE output files (EXPDAT.DMP) TABLES list of table namesCOMPRESS import into one extent (Y) RECORDLENGTH length of IO recordGRANTS export grants (Y) INCTYPE incremental export typeINDEXES export indexes (Y) RECORD track incr. export (Y)DIRECT direct path (N) TRIGGERS export triggers (Y)LOG log file of screen output STATISTICS analyze objects (ESTIMATE)ROWS export data rows (Y) PARFILE parameter filenameCONSISTENT cross-table consistency(N) CONSTRAINTS export constraints (Y)OBJECT_CONSISTENT transaction set to read only during object export (N)FEEDBACK display progress every x rows (0)FILESIZE maximum size of each dump fileFLASHBACK_SCN SCN used to set session snapshot back toFLASHBACK_TIME time used to get the SCN closest to the specified timeQUERY select clause used to export a subset of a tableRESUMABLE suspend when a space related error is encountered(N)RESUMABLE_NAME text string used to identify resumable statementRESUMABLE_TIMEOUT wait time for RESUMABLE TTS_FULL_CHECK perform full or partial dependency check for TTSVOLSIZE number of bytes to write to each tape volumeTABLESPACES list of tablespaces to exportTRANSPORT_TABLESPACE export transportable tablespace metadata (N)TEMPLATE template name which invokes iAS mode export

USERID must be the first parameter on the command line.Keyword Description (Default) Keyword Description (Default)--------------------------------------------------------------------------USERID username/password FULL import entire file (N)BUFFER size of data buffer FROMUSER list of owner usernamesFILE input files (EXPDAT.DMP) TOUSER list of usernamesSHOW just list file contents (N) TABLES list of table namesIGNORE ignore create errors (N) RECORDLENGTH length of IO recordGRANTS import grants (Y) INCTYPE incremental import typeINDEXES import indexes (Y) COMMIT commit array insert (N)ROWS import data rows (Y) PARFILE parameter filenameLOG log file of screen output CONSTRAINTS import constraints (Y)DESTROY overwrite tablespace data file (N)INDEXFILE write table/index info to specified fileSKIP_UNUSABLE_INDEXES skip maintenance of unusable indexes (N)FEEDBACK display progress every x rows(0)TOID_NOVALIDATE skip validation of specified type ids FILESIZE maximum size of each dump fileSTATISTICS import precomputed statistics (always)RESUMABLE suspend when a space related error is encountered(N)RESUMABLE_NAME text string used to identify resumable statementRESUMABLE_TIMEOUT wait time for RESUMABLE COMPILE compile procedures, packages, and functions (Y)STREAMS_CONFIGURATION import streams general metadata (Y)STREAMS_INSTANTIATION import streams instantiation metadata (N)DATA_ONLY import only data (N)VOLSIZE number of bytes in file on each volume of a file on tapeThe following keywords only apply to transportable tablespacesTRANSPORT_TABLESPACE import transportable tablespace metadata (N)TABLESPACES tablespaces to be transported into databaseDATAFILES datafiles to be transported into databaseTTS_OWNERS users that own data in the transportable tablespace set

导出模式有四种,数据库,表空间,用户,表级四个级别。 对于数据库级的导入导出,需要拥有exp_full_database权限,一般这个操作也是通过dba来执行,但是使用的场景相对比较少。 一个简单例子如下: exp n1/n1 file=db_backup.dmp buffer=9102000 log=db_backup.log full=Y 至于导入,就不能直接使用全库导入了,一般都按照要去来看哪些数据缺失了,针对性的补充导入。 对于表空间的导入导出,这个功能和表空间传输的特性是相关联的,如果要使用表空间传输,需要用到,transport_tablespaces,tablespace这两个参数而且需要使用sys来做这个操作。 一个简单的例子如下 导出

exp \'sys/oracle@PROD as sysdba\' file=hr_PROD.dmp transport_tablespace=y tablespaces=tbs4

导入: imp \'sys/oracle123@repos as sysdba\' file=hr_PROD.dmp transport_tablespace=y tablespaces=tbs4 datafiles=/u01/app/db/oradata/repos/tbs04.dbf

对于用户级的导入导出,可能使用要频繁一些。 导出的简单示例,导出appc下的所有信息,导出dump为a.dmp exp n1/n1 file=a.dmp owner=appc 导入的时候,导入到work账户中 imp n1/n1 file=a.dmp fromuser=appc touser=work 最后就是表级的导入导出,使用频率最为频繁。 最简单的一个例子就是 exp n1/n1 file=a.dmp tables=TEST imp appc/appc file=a.dmp tables=TEST 其实我们来做些更多的使用补充。 -->使用parfile来完成复杂的导入导出 这个功能可能在做一些动态的数据导入导出的时候尤为有用,可以只关注于parfile的部分,比如我们导出appc下的表test1,test2,test3 就可以定义parfile appc.parfile,内容为 tables=test1,test2,test3 导入导出命令类似 exp appc/appc file=a.dmp parfile=appc.parfile logfile=appc_exp.log 导入命令类似 imp appc/appc file=a.dmp parfile=appc.parfile logfile=appc_exp.log 如果要指定导出几十个,上百个表,使用parfile就能避免命令的繁琐。 -->使用query来做细粒度的导入导出 SQL> select object_id from test; OBJECT_ID ---------- 20 46 如果我只想导出object_id为20的数据,就可以使用query来进行逻辑层面的导出。 [ora11g@rac1 ora11g]$ exp n1/n1 file=a.dmp tables=test query=\'where object_id=20\' About to export specified tables via Conventional Path ... . . exporting table TEST 1 rows exported Export terminated successfully without warnings. 如果要实现复杂的逻辑导出,也未尝不可。 -->生成数据脚本 可能对于生成ddl脚本的功能大家并不在意。但是在特定的场景中也是很实用的。 比如我们导出表test,t的创建脚本。

[ora11g@rac1 ora11g]$ exp n1/n1 file=a.dmp tables=test,t rows=n
Export: Release 11.2.0.3.0 - Production on Sun Jan 25 06:44:11 2015
Note: table data (rows) will not be exported
About to export specified tables via Conventional Path ...
. . exporting table                           TEST
. . exporting table                              T
Export terminated successfully without warnings.

然后使用imp来生成ddl脚本,这个过程不是在做实际的导入,只是在生成脚本。

[ora11g@rac1 ora11g]$ imp n1/n1 file=a.dmp indexfile=a.log tables=test,t
Import: Release 11.2.0.3.0 - Production on Sun Jan 25 06:45:04 2015
Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.
Export file created by EXPORT:V11.02.00 via conventional path
import done in AL32UTF8 character set and AL16UTF16 NCHAR character set
Import terminated successfully without warnings.
[ora11g@rac1 ora11g]$ ls -lrt
total 28
-rw-r--r-- 1 ora11g dba 24576 Jan 25 06:44 a.dmp
-rw-r--r-- 1 ora11g dba  1610 Jan 25 06:45 a.log

生成的脚本如下,可能还需要进一步处理,但是相对来说也算比较清晰了。

[ora11g@rac1 ora11g]$ less a.log 
REM  CREATE TABLE "N1"."TEST" ("OWNER" VARCHAR2(30) NOT NULL ENABLE, 
REM  "OBJECT_NAME" VARCHAR2(30) NOT NULL ENABLE, "SUBOBJECT_NAME" 
REM  VARCHAR2(30), "OBJECT_ID" NUMBER NOT NULL ENABLE, "DATA_OBJECT_ID" 
REM  NUMBER, "OBJECT_TYPE" VARCHAR2(19), "CREATED" DATE NOT NULL ENABLE, 
REM  "LAST_DDL_TIME" DATE NOT NULL ENABLE, "TIMESTAMP" VARCHAR2(19), 
REM  "STATUS" VARCHAR2(7), "TEMPORARY" VARCHAR2(1), "GENERATED" 
REM  VARCHAR2(1), "SECONDARY" VARCHAR2(1), "NAMESPACE" NUMBER NOT NULL 
REM  ENABLE, "EDITION_NAME" VARCHAR2(30)) PCTFREE 10 PCTUSED 40 INITRANS 1 
REM  MAXTRANS 255 STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 
REM  FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT) TABLESPACE 
REM  "POOL_DATA" LOGGING NOCOMPRESS ;
REM  CREATE TABLE "N1"."T" ("OWNER" VARCHAR2(30), "OBJECT_NAME" 
REM  VARCHAR2(128), "SUBOBJECT_NAME" VARCHAR2(30), "OBJECT_ID" NUMBER, 
REM  "DATA_OBJECT_ID" NUMBER, "OBJECT_TYPE" VARCHAR2(19), "CREATED" DATE, 
REM  "LAST_DDL_TIME" DATE, "TIMESTAMP" VARCHAR2(19), "STATUS" VARCHAR2(7), 
REM  "TEMPORARY" VARCHAR2(1), "GENERATED" VARCHAR2(1), "SECONDARY" 
REM  VARCHAR2(1), "NAMESPACE" NUMBER, "EDITION_NAME" VARCHAR2(30)) PCTFREE 
REM  10 PCTUSED 40 INITRANS 1 MAXTRANS 255 STORAGE(INITIAL 2097152 NEXT 
REM  1048576 MINEXTENTS 1 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL 
REM  DEFAULT) TABLESPACE "POOL_DATA" LOGGING NOCOMPRESS ;
CONNECT N1;
CREATE UNIQUE INDEX "N1"."IND_T" ON "T" ("OBJECT_ID" ) PCTFREE 10 INITRANS 
2 MAXTRANS 255 STORAGE(INITIAL 262144 NEXT 1048576 MINEXTENTS 1 FREELISTS 
1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT) TABLESPACE "POOL_DATA" LOGGING ;

-->能够提升性能的参数 在导入导出的过程中,为了提高性能不妨考虑以下几个参数 grants=n --一般来说数据的导入导出,是不需要这些权限信息的,我们需要的只是数据。 statistics=none --统计信息很可能不需要,多个环境之间的数据量不同,尤其是大的分区表,如果导入统计信息还是很耗时的。可以酌情使用 constraints=n --在数据导入的过程中,很可能不需要这个选项,大多数情况下,不需要我们来改变目标环境的结构 indexes=n --这个选项一般也是不需要的,很可能目标环境已经有对应的索引了。 buffer=9102000 这个参数很重要,对于exp/imp来说,根据自己的条件来设定,我一般设置为9M,基本都够用了。

原文发布于微信公众号 - 杨建荣的学习笔记(jianrong-notes)

原文发表时间:2015-01-25

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏乐沙弥的世界

Oracle 控制文件(CONTROLFILE)

为二进制文件,初始化大小由CREATE DATABASE指定,可以使用RMAN备份

1222
来自专栏乐沙弥的世界

Oracle 数据字典和数据字典视图

是元数据的集合,从逻辑上和物理上描述了数据库及内容,存储于SYSTEM与SYSAUX表空间内的若干段。

823
来自专栏杨建荣的学习笔记

记一次数据库重启后归档急剧增加的问题(98天)

在本地的环境中测试外部表的性能,由于空间有限,不一会儿归档的空间就爆了。然后文件貌似出现了系统级的问题,刚刚rm掉的归档日志文件。隔了几秒钟再ls,就出现了。怎...

3644
来自专栏数据库新发现

在Mac上通过Docker部署Oracle Database 12.2版本

Oracle 已经宣布支持了Docker部署,这也让我们在Mac上部署 Oracle 数据库有了多一个选择,这是我的第一个Docker应用,非常简便快速的就完...

3106
来自专栏乐沙弥的世界

cannot fetch plan for SQL_ID

  SQL tuning过程中离不开分析SQL语句的执行计划。在一次提取执行计划的时候碰到cannot fetch plan for SQL_ID的错误提示。根...

952
来自专栏乐沙弥的世界

ORA-02019 错误处理

       ORA-02019 错误提示是未找到远程数据库的连接说明,通常发生在本地数据库无法连接到远程数据库。引发该问题的原因很多,比如网络连接,连接方式(...

1201
来自专栏乐沙弥的世界

高水位线和全表扫描

   高水位线好比水库中储水的水位线,用于描述数据库中段的扩展方式。高水位线对全表扫描方式有着至关重要的影响。当使用delete 操作 表记录时,高水位线并不...

812
来自专栏数据和云

追本溯源:Oracle 只读表空间的探索实践

作者简介 ? 胡中豪 云和恩墨西区交付工程师,多年一线 DBA 经验,曾服务于运营商、电网、政府行业、银行等行业客户;擅长数据库故障处理、性能优化、实施升级 本...

2913
来自专栏杨建荣的学习笔记

物化视图相关的性能改进 (r7笔记第58天)

今天早上开发的一个同事找到我说他早上做了一个统计查询,但是感觉速度很慢,已经过了一个小时了还没有反应。想让我看看是什么情况。 我通过v$session查到有一个...

3415
来自专栏乐沙弥的世界

Oracle expdp 时遭遇ORA-39125 ORA-04063

    数据库在使用DataPump导出时碰到了ORA-39125与ORA-04063。完整的ORA-39125提示是Worker unexpected fat...

1201

扫码关注云+社区

领取腾讯云代金券