`
javaoldboy
  • 浏览: 70367 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

exp/imp工具的使用

阅读更多

Export/Import 使用技巧与常见错误

Export 和 Import 是一对读写Oracle数据的工具. Export 将 Oracle 数据库中的数据输出到操作系统文件中, Import 把这些文件中的数据读到Oracle 数据库中. Export/Import可以用来完成以下工作: 数据归档, 数据库升级, 备份数据库, 把数据从一个数据库移到另一个数据库, 回收数据库存储碎片等等.
  
   使用Export除了要保证磁盘或磁带上有足够的空间, 还必须执行expvew.sql和expvew.sql来创建Export使用的示图, 并创建EXP_FULL_DATABASE ROLE. 使用Export的用户应具有CREATE SESSION的权限, 若要Export其他用户的表还要有EXP_FULL_DATABASE ROLE.同样, 使用Import必须用catex.sql来创建IMP_FULL_DATABASE ROLE. 使用Import的用户应具有CREATE SESSION的权限. Import只能读入用Export创建的文件. 如果该文件是全库Export, 使用Import的用户还要有IMP_FULL_DATABASE ROLE.   

   Export/Import有三个级别: 表级, 用户级和全数据库级.

   表级允许Export/Import指定的表而不涉及其他数据库对象. 用户级Export/Import只针对属于指定用户的全部数据库对象. 只有拥有EXP_FULL_DATABASE/IMP_FULL_DATABASE ROLE 的用户才能使用全数据库级的Export/Import.

      有三种方式执行Export/Import: 参数文件方式, 命令行方式和交互式.

      使用参数文件是一种比较好的方式, 格式为:

         Exp <username/password> PARFILE = <filename>

         Imp <username/password> PARFILE = <filename>

      命令行方式是指在命令行中指定参数:

         Exp <username/password> TABLES = (emp,dept) GRANTS = y

         Imp <username/password> FROMUSER = scott TOUSER = test TABLES = (emp,dept)

      交互式只要敲入Exp或Imp然后回答屏幕上的提问即可.

下面介绍一些EXPORT/IMPORT的使用技巧

   - 把数据库对象从一个用户移到另一个用户

      Oracle 不允许直接改变表的拥有者, 利用Export/Import可以达到这一目的.

      假设要把表 T 的拥有者User1改为User2,  具体步骤是:

         - exp system/manager tables = User1.T

         - imp system/manager fromuser = User1 touser = User2 tables = T

         - drop table User1.T

         - 把数据库对象从一个表空间移到另一个表空间

      建表时可以指定表空间, 表空间一经确定就部能随意改变. 若要表 T 从表空间 tbs1移到表空间 tbs2, 就要采用以下方法:

         - exp <user/passwd> tables = T

         - imp <user/passwd> tables = T indexfile =  temp.sql

         - drop table T

         - 编辑 temp.sql 只保留所需的建表命令并指定表空间为tbs2

         - 以表的所有者执行temp.sql

         - imp <user/passwd> tables = T ignore = Y

     - 只输出一个的表空间

      通常数据库设计成用户若属于某个表空间, 那么这个用户创建的数据库对象也在该表空间内.

   Export某个表空间可用如下方法:

         - 查看表空间内所有用户

             spool owners
           
             select owner

             from dba_segments

             where tablespace_name = '<TablespaceName>';
           

            spool off

            
         - 查看表空间内所有数据库对象

             spool objects

             select owner, object_name, object_type

             from  dba_objects

             where owner = 'owner1'

             or   owner = 'owner2'

                  ...

             or   owner = 'ownern';

             spool off

        - 作表级Export         

   - 从Exp文件中提取创建数据库对象的命令

     在IMPORT时使用 'INDEXFILE =  FileName', IMPORT把创建数据库对象的命令输出到指定的文件中, 编辑后运行这个文件就能建立数据库对象.

   

下面介绍Export/Import 使用中几个常见的问题和解决办法

   - Export/Import 使用不同的字符集

      Export文件中包含着字符信息. 如过输入/输出都使用担字节字符集, 如EBCDIC或US7ASCII, 输入时将自动进行字符集转换. 转换过程中, 若输出文件中含有的目标字符集中不能匹配的字符会自动设成缺省字符.

      对于多字节字符集, 如ZHS16CGB231280, 通常不能自动转换, 只有在字符串长度不变的情况下才能自动转换.      

   - 空间不够 -- 碎片问题

      有些时候, 即使数据库仍有足够的空间, 使用IMPORT时却出空间不够的错误. 出现这种现象通常是由于数据库中存在碎片, 即有很多小的不连续的空闲空间. 解决办法是先将数据库全库EXPORT(FULL=Y), SHUTDOWN数据库, 重新建库(CREATE DATABASE)后用IMPORT FULL=Y恢复数据.


   - ROLLBACK段不够

      Export/Import使用过程中, 如果数据量很大会出现'ROLLBACK段不够'的错误. 这时要建一个足够大的ROLLBACK段, 使它ONLINE而其他ROLLBACK段OFFLINE. 这样, Export/Import使用这个大ROLLBACK段, 从而避免上述现象.




* 空间不够 -- 碎片问题

解决办法是先将数据库全库EXPORT(FULL=Y), SHUTDOWN数据库, 重新建库(CREATE DATABASE)后用IMPORT FULL=Y恢复数据.
*/

不同观点:

解决碎片,应该在表空间这个层次上就可以了,
1。exp 出要整理的表空间的各个用户。
2。删除表空间,重新建立该表空间
3。再imp

   - ROLLBACK段不够

  /*    Export/Import使用过程中, 如果数据量很大会出现'ROLLBACK段不够'的错误. 这时要建一个足够大的ROLLBACK段, 使它ONLINE而其他ROLLBACK段OFFLINE. 这样, Export/Import使用这个大ROLLBACK段, 从而避免上述现象.

*/

imp时使用参数 commit=y ,就可以避免要求很大的回退段,
imp 到底用哪个ROLLBACK段是没法指定的,
如果系统刚启动,oracle顺序地用 初始化参数文件中指定的ROLLBACK段
而后,事务以“最少使用原则”选取使用ROLLBACK段。
除非,在imp前,让一个大ROLLBACK段online,紧接着imp,
否则很难说,oralce就正好用大ROLLBACK段。

分享到:
评论

相关推荐

    Oracle中利用EXP/IMP工具实现数据迁移

    通过EXP/IMP可以实现产品系统的跨平台的迁移,需要迁移的数据库已经部署了高级复制环境,打算进行一系列的测试,测试包含高级复制环境数据库在通过 EXP/IMP工具迁移到新的环境中,复制环境是否生效。文中通过实例...

    exp/imp导出导入工具的使用

    exp/imp导出导入工具的使用手册,我也是在别处找的资料,借花献佛

    Oracle数据库逻辑增量备份之exp/imp

    二、逻辑备份恢复工具exp/imp 2 1、逻辑备份原理 2 2、exp语法和参数 2 3、imp语法和参数 3 三、exp逻辑备份 4 1、exp表模式备份 4 2、exp用户模式备份 5 3、exp全库模式备份 5 四、imp逻辑恢复 6 1、imp表模式恢复 ...

    oracle exp imp详解

    导入/导出是ORACLE幸存的最古老的两个命令行工具,其实我从来不认为Exp/Imp是一种好的备份方式,正确的说法是Exp/Imp只能是一个好的转储工具,特别是在小型数据库的转储,表空间的迁移,...下面说明一下EXP/IMP的使用。

    EXP IMP详解

    导入/导出是ORACLE幸存的最古老的两个命令行工具,其实我从来不认为Exp/Imp是一种好的备份方式,正确的说法是Exp/Imp只能是一个好的转储工具,特别是在小型数据库的转储,表空间的迁移,...下面说明一下EXP/IMP的使用。

    Oracle 管道 解决Exp/Imp大量数据处理问题

    Oracle的exp/imp是许多用户经常使用的两个工具. 它们常被用来做数据库的逻辑备份,数据库重组和数据转移等工作.

    ORACLE12c客户端含sqlplus、exp、imp等工具

    oracle版本绿色客户端(只收集了32位的,可在32、64下运行),并提供了相应的启动脚本,不需要任何配置,可随时随地拷贝使用。...本包提供windows下的32位绿色免安装、简易oracle客户端,含sqlplus、exp、imp等工具

    oracle_exp_imp详解

    导入/导出是ORACLE幸存的最古老的两个命令行工具,其实我从来不认为Exp/Imp是一种好的备份方式,正确的说法是Exp/Imp只能是一个好的转储工具,特别是在小型数据库的转储,表空间的迁移,表的抽取,检测逻辑和物理...

    Oracle备份恢复工具EXPIMP的使用

    Oracle备份恢复工具EXPIMP的使用

    oracle11G_64位的imp.exe及exp.exe BIN包

    oracle11g的bin包括imp.exe、exp.exe 64位亲测可用 oracle11g的bin包括imp.exe、exp.exe 64

    Oracle11G客户端64位windows环境-sqlldr-imp-sqlplus等可用.zip

    oracle11g基本客户端,主要是用于windows环境下sqlplus,sqlldr,exp,imp这几个命令。最最主要的还是sqlldr,想找个单独可用的sqlldr,在Oracle 10g Client 精简优化安装包不到12M ...

    oracle 11.2.0.4 imp exp sqlldr 工具及rdbms包

    很多同学安装完精简版的oracle11.2.0.4的客户端后,没有对应的exp、imp、sqlldr工具。此资源包可直接解压使用

    oracle10g 导入导出工具

    文档里面共包含四个文件,对应oracle10g 的 exp/imp,expdb/impdb

    exp和imp用法和介绍

    exp和imp用法和介绍,Oracle Export/Import工具用于在数据库之间传递数据。 Export从数据库中导出数据到dump文件中 Import从dump文件中到入数据导数据库中 下面是一般使用他们的情况 (1)、两个数据库之间传送...

    Oracle-ImpExp

    Oracle-dmp数据库文件导入导出工具 源码: http://code.google.com/p/oracle-impexp/downloads/list

    浅谈入门级oracle数据库数据导入导出步骤

    2.如果熟悉命令,建议用exp/imp命令导入导出,避免第三方工具版本差异引起的问题,同时效率更高,但特别注意:采用命令时要注意所使用的用户及其权限等细节。 3.在目标数据库导入时需要创建与导出时相同的用户名...

    linux oracle imp exp 执行命令安装

    linux oracle 远程连接oracle服务器时,客服端机器需要安装imp exp命令才可以操作操作数据库导入/导出数据

    oracle11g的imp exp

    oracle11g的imp exp,oracle11g的imp exp,oracle11g的imp exp

    oracle数据库备份与恢复总结

    对rman、exp/imp等备份工具的使用总结

Global site tag (gtag.js) - Google Analytics