Chinaunix首页 | 论坛 | 博客
  • 博客访问: 260301
  • 博文数量: 54
  • 博客积分: 2668
  • 博客等级: 少校
  • 技术积分: 560
  • 用 户 组: 普通用户
  • 注册时间: 2009-05-06 01:08
文章分类

全部博文(54)

文章存档

2011年(14)

2010年(14)

2009年(26)

分类: Oracle

2010-09-28 18:06:27

exp&imp

简介:expimp做为oracle的数据导出导入工具,很实用的。可以说是oracle数据库管理员的一把利器.

一、用途

1、应用于不同系统平台间移植数据。

2、数据库的备份和恢复

3、应用用户的数据移动

二、基本语法

1EXP

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

 

 

2IMP

具有三种模式(完全、用户、表)

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的所有对象被导入到数据库中了。必须指定FROMUSERTOUSER参数,这样才能导入数据。

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_

  确定字符集相同后,就开始导数据吧。

为什么要确定字符集呢,如果导出时的语言环境和数据库的语言环境

不一样的话是会出现报错信息的,我就遇到过,EXP00091 Exporting questionable statistics.的信息,其

实它就是experror 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中执行 EXPUSERID 必须用三个引号,在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;

阅读(2539) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~