分类: Oracle
2010-09-28 18:06:27
exp&imp
简介:exp和imp做为oracle的数据导出导入工具,很实用的。可以说是oracle数据库管理员的一把利器.
一、用途
1、应用于不同系统平台间移植数据。
2、数据库的备份和恢复
3、应用用户的数据移动
二、基本语法
1、EXP
a.完全
exp system/manager buffer=80000 file=/data/oraclebak.dmp full=y
需要具备特殊的权限
b.用户模式
exp test/test buffer=80000 file=/data/oraclebak.dmp owner=test log=xx.log
用户所有的对象都会被导出
3.表模式
exp test/test buffer=80000 file=/data/oraclebak.dmp log=xx.log tables=test1,test2..testn
导出test用户的某些表
其他关键字详细见帮助
exp help=y Keyword Description (Default) Keyword Description (Default) -------------------------------------------------------------------------- USERID username/password FULL export entire file (N) BUFFER size of data buffer OWNER list of owner usernames FILE output files (EXPDAT.DMP) TABLES list of table names COMPRESS import into one extent (Y) RECORDLENGTH length of IO record GRANTS export grants (Y) INCTYPE incremental export type INDEXES 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 filename CONSISTENT 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 file FLASHBACK_SCN SCN used to set session snapshot back to FLASHBACK_TIME time used to get the SCN closest to the specified time QUERY select clause used to export a subset of a table RESUMABLE suspend when a space related error is encountered(N) RESUMABLE_NAME text string used to identify resumable statement RESUMABLE_TIMEOUT wait time for RESUMABLE TTS_FULL_CHECK perform full or partial dependency check for TTS VOLSIZE number of bytes to write to each tape volume TABLESPACES list of tablespaces to export TRANSPORT_TABLESPACE export transportable tablespace metadata (N) TEMPLATE template name which invokes iAS mode export
|
2、IMP
具有三种模式(完全、用户、表)
a、完全
imp system/manager buffer=80000 file=/data/oraclebak.dmp full=y
b、用户模式
imp test/test buffer=80000 file=/data/oraclebak.dmp fromuser=test touser=test log=xx.log
这样用户test的所有对象被导入到数据库中了。必须指定FROMUSER、TOUSER参数,这样才能导入数据。
c、表空间模式
imp test/test buffer=80000 file=/data/oraclebak.dmp owner=test tables=test1,test2...testn
其他关键字详细见帮助
imp help=y Keyword Description (Default) Keyword Description (Default) -------------------------------------------------------------------------- USERID username/password FULL import entire file (N) BUFFER size of data buffer FROMUSER list of owner usernames FILE input files (EXPDAT.DMP) TOUSER list of usernames SHOW just list file contents (N) TABLES list of table names IGNORE ignore create errors (N) RECORDLENGTH length of IO record GRANTS import grants (Y) INCTYPE incremental import type INDEXES import indexes (Y) COMMIT commit array insert (N) ROWS import data rows (Y) PARFILE parameter filename LOG log file of screen output CONSTRAINTS import constraints (Y) DESTROY overwrite tablespace data file (N) INDEXFILE write table/index info to specified file SKIP_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 file STATISTICS import precomputed statistics (always) RESUMABLE suspend when a space related error is encountered(N) RESUMABLE_NAME text string used to identify resumable statement RESUMABLE_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) VOLSIZE number of bytes in file on each volume of a file on tape
|
案例1
需求:将生产环境中的数据导入测试环境中,用于测试
1.导出数据前的准备
查看生产环境中和测试环境中的字符集。有关字符集的介绍可查看我的另一篇文章:
select * from nls_database_parameters
生产环境:
select userenv('language') from dual;
USERENV('LANGUAGE')
----------------------------------------------------
AMERICAN_AMERICA.AL32UTF8
测试环境:
select userenv('language') from dual;
USERENV('LANGUAGE')
----------------------------------------------------
AMERICAN_AMERICA.AL32UTF8
在生产环境中的terminal
su - oracle
export NLS_LANG=AMERICAN_AMERICA.AL32UTF
env|grep NLS_
确定字符集相同后,就开始导数据吧。
为什么要确定字符集呢,如果导出时的语言环境和数据库的语言环境
不一样的话是会出现报错信息的,我就遇到过,EXP-00091 Exporting questionable statistics.的信息,其
实它就是exp的error message,它产生的原因是因为我们exp工具所在的环境变量是的NLS LANG中的NLS_CHARCATERSET不一致引起的。
但需要说明的是,exp-00091这个error对所生成的dump文件没有影响,生成的dump文件还可以正常imp。
解决方案就是,导出时的语言环境和数据库一样就OK。
为什么导出的字符集要和目标库的一样呢?当然是为了避免因为字符集的问题出现错误。我因为没关注生产库中的字符集和测试库的字符,
遇到过的就是
IMP-00098: INTERNAL ERROR: impccr2
IMP-00017: following statement failed with ORACLE error 4043:
"ALTER PROCEDURE "P_USER_LEVEL_CHANGE" COMPILE REUSE SETTINGS TIMESTAMP '201"
"0-07-09:15:59:29'"
IMP-00003: ORACLE error 4043 encountered
ORA-04043: object P_USER_LEVEL_CHANGE does not exist
About to enable constraints...
Import terminated successfully with warnings
所以导出时的字符集必须要注意哦
案例2表空间传输
oracle exp备份在表空间传输中,你一定要注意在表空间传输的实际操作中要有四个项目是最值得你去注意的,以下的文章就是针对这四个项目进行一个详细的描述,如果你对Oracle exp备份在表空间传输的实际操作感兴趣的话,不防一看。
Oracle exp备份在表空间传输
建议:10g以上使用,但我试了在9i没有找到相对应的检查表空是否传输的语句,10g 支持跨平台的表空间传输
注意:
l.索引在待传输表空间集中而表却不在。(注意,如果表在待传输表空间集中,而索引不在并不违反自包含原则,当然如果你坚持这样传输的话,会造成目标库中该表索引丢失)。
2.分区表中只有部分分区在待传输表空间集(对于分区表,要么全部包含在待传输表空间集中,要么全不包含)。
3.待传输表空间中,对于引用完整性约束,如果约束指向的表不在待传输表空间集,则违反自包含约束;但如果不传输该约束,则与约束指向无关。
4.对于包含LOB列的表,如果表在待传输表空间集中,而Lob列不在,也是违反自包含原则的。
a.查看表空间包含那些XML文件
select distinct p.tablespace_name
from dba_tablespaces p, dba_xml_tables x, dba_users u, all_all_tables t
where t.table_name = x.table_name
and t.tablespace_name = p.tablespace_name
and x.owner = u.username
b.检测一个表空间是否符合传输标准的方法:
SQL > exec sys.dbms_tts.transport_set_check('tablespace_name',true);
SQL > select * from sys.transport_set_violations;
c.简要使用步骤
1.设置表空间为只读(假定表空间名字为APP_Data 和APP_Index)
SQL > alter tablespace app_data read only;
SQL > alter tablespace app_index read only;
2.发出EXP 命令
SQL> host exp userid='''sys/password as sysdba''' transport_tablespace=y
tablespaces=(app_data, app_index)
以上需要注意的是:(或则参考我自己写的 表空间导入和导出例题)
为了在SQL中执行 EXP,USERID 必须用三个引号,在UNIX 中也必须注意避免"/"的使用
在816 和以后,必须使用sysdba 才能操作
这个命令在SQL中必须放置在一行(这里是因为显示问题放在了两行)
3.拷贝.dbf数据文件(以及.dmp 文件)到另一个地点,即目标数据库可以是cp(unix)或copy(windows)或通过ftp 传输文件(一定要在bin方式)
4. 把本地的表空间设置为读写
$ alter tablespace app_data read write;
$ alter tablespace app_index read write;
5.在目标数据库附加该数据文件 (直接指定数据文件名)
(表空间不能存在,必须建立相应用户名或者用fromuser/touser)
$ imp file=expdat.dmp userid=sys/password as sysdba
transport_tablespace=y tablespaces=app_data,app_index tts_owners=hr,oe
6.设置目标数据库表空间为读写
$ alter tablespace app_data read write;
$ alter tablespace app_index read write;