知识大全 Oracle中逻辑导出Exp/导入Imp的详细介绍以及参数介绍

Posted 数据库

篇首语:贵在坚持,难在坚持,成在坚持。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 Oracle中逻辑导出Exp/导入Imp的详细介绍以及参数介绍相关的知识,希望对你有一定的参考价值。

Oracle中逻辑导出Exp/导入Imp的详细介绍以及参数介绍  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

  导入/导出是ORACLE幸存的最古老的两个命令行工具 其实我从来不认为Exp/Imp是一种好的备份方式 正确的说法是Exp/Imp只能是一个好的转储工具 特别是在小型数据库的转储 表空间的迁移 表的抽取 检测逻辑和物理冲突等中有不小的功劳 当然 我们也可以把它作为小型数据库的物理备份后的一个逻辑辅助备份 也是不错的建议 对于越来越大的数据库 特别是TB级数据库和越来越多数据仓库的出现 EXP/IMP越来越力不从心了 这个时候 数据库的备份都转向了RMAN和第三方工具 下面说明一下EXP/IMP的使用

  如何使exp的帮助以不同的字符集显示 set nls_lang=simplified chinese_china zhs gbk 通过设置环境变量 可以让exp的帮助以中文显示 如果set nls_lang=American_america 字符集 那么帮助就是英文的了

  EXP的所有参数(括号中为参数的默认值)

  USERID 用户名/口令 如 USERID=duanl/duanl

  FULL 导出整个数据库 (N)

  BUFFER 数据缓冲区的大小

  OWNER 所有者用户名列表 你希望导出哪个用户的对象 就用owner=username

  FILE 输出文件 (EXPDAT DMP)

  TABLES 表名列表 指定导出的table名称 如 TABLES=table table

  PRESS 导入一个extent (Y)

  RECORDLENGTH IO 记录的长度

  GRANTS 导出权限 (Y)

  INCTYPE 增量导出类型

  INDEXES 导出索引 (Y)

  RECORD 跟踪增量导出 (Y)

  ROWS 导出数据行 (Y)

  PARFILE 参数文件名 如果你exp的参数很多 可以存成参数文件

  CONSTRAINTS 导出约束 (Y)

  CONSISTENT 交叉表一致性

  LOG 屏幕输出的日志文件

  STATISTICS 分析对象 (ESTIMATE)

  DIRECT 直接路径 (N)

  TRIGGERS 导出触发器 (Y)

  FEEDBACK 显示每 x 行 ( ) 的进度

  FILESIZE 各转储文件的最大尺寸

  QUERY 选定导出表子集的子句

  下列关键字仅用于可传输的表空间

  TRANSPORT_TABLESPACE 导出可传输的表空间元数据 (N)

  TABLESPACES 将传输的表空间列表

  IMP的所有参数(括号中为参数的默认值)

  USERID 用户名/口令

  FULL 导入整个文件 (N)

  BUFFER 数据缓冲区大小

  FROMUSER 所有人用户名列表

  FILE 输入文件 (EXPDAT DMP)

  TOUSER 用户名列表

  SHOW 只列出文件内容 (N)

  TABLES 表名列表

  IGNORE 忽略创建错误 (N)

  RECORDLENGTH IO 记录的长度

  GRANTS 导入权限 (Y)

  INCTYPE 增量导入类型

  INDEXES 导入索引 (Y)

  MIT 提交数组插入 (N)

  ROWS 导入数据行 (Y)

  PARFILE 参数文件名

  LOG 屏幕输出的日志文件

  CONSTRAINTS 导入限制 (Y)

  DESTROY 覆蓋表空间数据文件 (N)

  INDEXFILE 将表/索引信息写入指定的文件

  SKIP_UNUSABLE_INDEXES 跳过不可用索引的维护 (N)

  ANALYZE 执行转储文件中的 ANALYZE 语句 (Y)

  FEEDBACK 显示每 x 行 ( ) 的进度

  TOID_NOVALIDATE 跳过指定类型 id 的校验

  FILESIZE 各转储文件的最大尺寸

  RECALCULATE_STATISTICS 重新计算统计值 (N)

  下列关键字仅用于可传输的表空间

  TRANSPORT_TABLESPACE 导入可传输的表空间元数据 (N)

  TABLESPACES 将要传输到数据库的表空间

  DATAFILES 将要传输到数据库的数据文件

  TTS_OWNERS 拥有可传输表空间集中数据的用户

  关于增量参数的说明 exp/imp的增量并不是真正意义上的增量 所以最好不要使用

  使用方法

  Exp parameter_name=value or Exp parameter_name=(value value ……)

  只要输入参数help=y就可以看到所有帮助

  EXP常用选项

   FULL 这个用于导出整个数据库 在ROWS=N一起使用时 可以导出整个数据库的结构 例如

  exp userid=test/test file= /db_str dmp log= /db_str log full=y rows=n press=y direct=y

  注 在oracle g中 userid这个是可以不用写的直接写 用户名/密码 就可以了像这样

  exp test/test file= /db_str dmp log= /db_str log full=y rows=n press=y direct=y

   OWNER和TABLE 这两个选项用于定义EXP的对象 OWNER定义导出指定用户的对象;TABLE指定EXP的table名称 例如

  exp userid=test/test file= /db_str dmp log= /db_str log owner=duanl

  注:有的时候我们可能会遇到只导出单表的情况 下面这种方法可以帮你解决问题

  exp userid=test/test file= /db_str dmp log= /db_str log table=nc_data fi_arap

   BUFFER和FEEDBACK 在导出比较多的数据时 我会考虑设置这两个参数 例如

  exp userid=test/test file=yw _ dmp log=yw _ _ log feedback= buffer= tables=WO OK_YT

   FILE和LOG 这两个参数分别指定备份的DMP名称和LOG名称 包括文件名和目录 例子见上面

   PRESS 参数不压缩导出数据的内容 用来控制导出对象的storage语句如何产生 默认值为Y 使用默认值 对象的存储语句的init extent等于当前导出对象的extent的总和 推荐使用PRESS=N

   FILESIZE该选项在 i中可用 如果导出的dmp文件过大时 最好使用FILESIZE参数 限制文件大小不要超过 G 如

  exp userid=duanl/duanl file=f f f f f filesize= G owner=scott

  这样将创建f dmp f dmp等一系列文件 每个大小都为 G 如果导出的总量小于 G

  EXP不必创建f bmp

  IMP常用选项

   FROMUSER和TOUSER 使用它们实现将数据从一个SCHEMA中导入到另外一个SCHEMA中 例如 假设我们做exp时导出的为test的对象 现在我们想把对象导入用户

  imp userid=test /test file=expdat dmp fromuser=test touser=test

   IGNORE GRANTS和INDEXES 其中IGNORE参数将忽略表的存在 继续导入 这个对于需要调整表的存储参数时很有用 我们可以先根据实际情况用合理的存储参数建好表 然后直接导入数据 而GRANTS和INDEXES则表示是否导入授权和索引 如果想使用新的存储参数重建索引 或者为了加快到入速度 我们可以考虑将INDEXES设为N 而GRANTS一般都是Y 例如 imp userid=test /test file=expdat dmp fromuser=test touser=test indexes=N

  表空间传输

  表空间传输是 i新增加的一种快速在数据库间移动数据的一种办法 是把一个数据库上的格式数据文件附加到另外一个数据库中 而不是把数据导出成Dmp文件 这在有些时候是非常管用的 因为传输表空间移动数据就象复制文件一样快

  关于传输表空间有一些规则 即

  ·源数据库和目标数据库必须运行在相同的硬件平台上

  ·源数据库与目标数据库必须使用相同的字符集

  ·源数据库与目标数据库一定要有相同大小的数据块

  ·目标数据库不能有与迁移表空间同名的表空间

  ·SYS的对象不能迁移

  ·必须传输自包含的对象集

  ·有一些对象 如物化视图 基于函数的索引等不能被传输

  可以用以下的方法来检测一个表空间或一套表空间是否符合传输标准

  exec sys dbms_tts transport_set_check(‘tablespace_name’ true);

  select * from sys transport_set_violation;

  如果没有行选择 表示该表空间只包含表数据 并且是自包含的 对于有些非自包含的表空间 如数据表空间和索引表空间 可以一起传输

  以下为简要使用步骤 如果想参考详细使用方法 也可以参考ORACLE联机帮助

   设置表空间为只读(假定表空间名字为APP_Data 和APP_Index)

  alter tablespace app_data read only;

  alter tablespace app_index read only;

   发出EXP命令

  SQL>host exp userid=”””sys/password as sysdba”””

  transport_tablespace=y tablespace=(app_data app_index)

  以上需要注意的是

  ·为了在SQL中执行EXP USERID必须用三个引号 在UNIX中也必须注意避免“/”的使用

  ·在 和以后 必须使用sysdba才能操作

  ·这个命令在SQL中必须放置在一行(这里是因为显示问题放在了两行)

   拷贝数据文件到另一个地点 即目标数据库

  可以是cp(unix)或copy(windows)或通过ftp传输文件(一定要在bin方式)

   把本地的表空间设置为读写

   在目标数据库附加该数据文件

  imp file=expdat dmp userid=”””sys/password as sysdba””” transport_tablespace=y “datafile=(c:tempapp_data c:tempapp_index)”

   设置目标数据库表空间为读写

  alter tablespace app_data read write;

  alter tablespace app_index read write;

  优化EXP/IMP的方法

  当需要exp/imp的数据量比较大时 这个过程需要的时间是比较长的 我们可以用一些方法来优化exp/imp的操作

  exp:使用直接路径 direct=y

  oracle会避开sql语句处理引擎 直接从数据库文件中读取数据 然后写入导出文件

  可以在导出日志中观察到: exp : table xxx will be exported in conventional path

  如果没有使用直接路径 必须保证buffer参数的值足够大

  有一些参数于direct=y不兼容 无法用直接路径导出可移动的tablespace 或者用query参数导出数据库子集

  当导入导出的数据库运行在不同的os下时 必须保证recordlength参数的值一致

  imp:通过以下几个途径优化

   避免磁盘排序

  将sort_area_size设置为一个较大的值 比如 M

   避免日志切换等待

  增加重做日志组的数量 增大日志文件大小

   优化日志缓冲区

  比如将log_buffer容量扩大 倍(最大不要超过 M)

   使用阵列插入与提交

  mit = y

  注意:阵列方式不能处理包含LOB和LONG类型的表 对于这样的table 如果使用mit = y 每插入一行 就会执行一次提交

   使用NOLOGGING方式减小重做日志大小

  在导入时指定参数indexes=n 只导入数据而忽略index 在导完数据后在通过脚本创建index 指定 NOLOGGING选项

  导出/导入与字符集

  进行数据的导入导出时 我们要注意关于字符集的问题 在EXP/IMP过程中我们需要注意四个字符集的参数 导出端的客户端字符集 导出端数据库字符集 导入端的客户端字符集 导入端数据库字符集

  我们首先需要查看这四个字符集参数

  查看数据库的字符集的信息

  SQL> select * from nls_database_parameters;

  PARAMETER VALUE

  

  NLS_LANGUAGE AMERICAN

  NLS_TERRITORY AMERICA

  NLS_CURRENCY $

  NLS_ISO_CURRENCY AMERICA

  NLS_NUMERIC_CHARACTERS

  NLS_CHARACTERSET ZHS GBK

  NLS_CALENDAR GREGORIAN

  NLS_DATE_FORMAT DD MON RR

  NLS_DATE_LANGUAGE AMERICAN

  NLS_SORT BINARY

  NLS_TIME_FORMAT HH MI SSXFF AM

  NLS_TIMESTAMP_FORMAT DD MON RR HH MI SSXFF AM

  NLS_TIME_TZ_FORMAT HH MI SSXFF AM TZH:TZM

  NLS_TIMESTAMP_TZ_FORMAT DD MON RR HH MI SSXFF AM TZH:TZM

  NLS_DUAL_CURRENCY $

  NLS_P BINARY

  NLS_NCHAR_CHARACTERSET ZHS GBK

  NLS_RDBMS_VERSION

  NLS_CHARACTERSET ZHS GBK是当前数据库的字符集

  我们再来查看客户端的字符集信息

  客户端字符集的参数NLS_LANG=_< territory >

  language 指定oracle消息使用的语言 日期中日和月的显示

  Territory 指定货币和数字的格式 地区和计算星期及日期的习惯

  Characterset 控制客户端应用程序使用的字符集 通常设置或等于客户端的代码页 或者对于unicode应用设为UTF

  在windows中 查询和修改NLS_LANG可在注册表中进行

  HKEY_LOCAL_MACHINESOFAREOracleHOMExx

  xx指存在多个Oracle_HOME时的系统编号

  在unix中

  $ env|grep NLS_LANG

  NLS_LANG=simplified chinese_china ZHS GBK

  修改可用

  $ export NLS_LANG=AMERICAN_AMERICA UTF

  通常在导出时最好把客户端字符集设置得和数据库端相同 当进行数据导入时 主要有以下两种情况

  ( ) 源数据库和目标数据库具有相同的字符集设置

  这时 只需设置导出和导入端的客户端NLS_LANG等于数据库字符集即可

  ( ) 源数据库和目标数据库字符集不同

  先将导出端客户端的NLS_LANG设置成和导出端的数据库字符集一致 导出数据 然后将导入端客户端的NLS_LANG设置成和导出端一致 导入数据 这样转换只发生在数据库端 而且只发生一次

  这种情况下 只有当导入端数据库字符集为导出端数据库字符集的严格超集时 数据才能完全导成功 否则 可能会有数据不一致或乱码出现

  不同版本的EXP/IMP问题

  一般来说 从低版本导入到高版本问题不大 麻烦的是将高版本的数据导入到低版本中 在Oracle i之前 不同版本Oracle之间的EXP/IMP可以通过下面的方法来解决

   在高版本数据库上运行底版本的catexp sql;

   使用低版本的EXP来导出高版本的数据;

   使用低版本的IMP将数据库导入到低版本数据库中;

   在高版本数据库上重新运行高版本的catexp sql脚本

  但在 i中 上面的方法并不能解决问题 如果直接使用低版本EXP/IMP会出现如下错误

  EXP : orACLE error %lu encountered

  orA : invalid column name

  这已经是一个公布的BUG 需要等到Oracle 才能解决 BUG号为 你可以到METALINK上去查看有关此BUG的详细信息

  BUG归BUG 我们的工作还是要做 在没有Oracle的支持之前 我们就自己解决 在Oracle i中执行下面的SQL重建exu rls视图即可

  Create or REPLACE view exu rls

  (objown objnam policy polown polsch polfun stmts copt enabled spolicy)

  AS select u name o name r pname r pfschma r ppname r pfname

  decode(bitand(r stmt_type ) Select )

  || decode(bitand(r stmt_type ) Insert )

  || decode(bitand(r stmt_type ) Update )

  || decode(bitand(r stmt_type ) Delete )

  r check_opt r enable_flag

  DECODE(BITAND(r stmt_type ) )

  from user$ u obj$ o rls$ r

  where u user# = o owner#

  and r obj# = o obj#

  and (uid = or

  uid = o owner# or

  exists ( select * from session_roles where role= Select_CATALOG_ROLE )

  )

  /

  grant select on sys exu rls to public;

  /

  可以跨版本的使用EXP/IMP 但必须正确地使用EXP和IMP的版本

   总是使用IMP的版本匹配数据库的版本 如 要导入到 中 使用 的IMP工具

cha138/Article/program/Oracle/201311/19071

相关参考

知识大全 Oracle数据导入导出imp/exp命令

Oracle数据导入导出imp/exp命令  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  如何在

知识大全 cmd命令行模式

  Oracle数据导入导出imp/exp就相当于oracle数据还原与备份exp命令可以把数据从远程数据库服务器导出到本地的dmp文件imp命令可以把dmp文件从本地导入到远处的数据库服务器中利用这

知识大全 oracle将数据导入指定表空间

在使用oracle的exp和imp导出导入的时候有时遇到需要导入的数据不是同一个用户的也不一定是同一个表空间例如源数据库上用户为aaa表空间aa目标数据库用户为bbb表空间bb当用imp导入以后查看发

知识大全 Oracle中RMAN和EXP/IMP转移数据实测

Oracle中RMAN和EXP/IMP转移数据实测  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 

知识大全 Oracle数据库exp导出问题

Oracle数据库|exp导出问题  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  昨天payme

知识大全 Oracle导出程序Exp的使用具体过程

Oracle导出程序Exp的使用具体过程  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!   Ora

知识大全 Oracle跨版本导出EXP-00003错误的解决

Oracle跨版本导出EXP-00003错误的解决  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 

知识大全 oracle数据库如何导出并重新导入

oracle数据库导出并重新导入 一导出数据库?将数据库TEST完全导出用户名scott密码tiger导出到D:\\testDBdmp中[plain]expscott/tiger@TESTf

知识大全 教你怎样在Oracle数据库中高速导出/导入

教你怎样在Oracle数据库中高速导出/导入  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  迄今

知识大全 oraclesqlloader全攻略

一sqlloader的特点oracle自己带了很多的工具可以用来进行数据的迁移备份和恢复等工作但是每个工具都有自己的特点比如说exp和imp可以对数据库中的数据进行导出和导出的工作是一种很好的数据库备