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

oracle exp/imp的备份(导入/导出)

    博客分类:
  • db
阅读更多

导 入/导出是ORACLE幸存的最古老的两个命令行工具,其实我从来不认为Exp/Imp是一种好的备份方式,正确的说法是Exp/Imp只能是一个好的转 储工具,特别是在小型数据库的转储,表空间的迁移,表的抽取,检测逻辑和物理冲突等中有不小的功劳。当然,我们也可以把它作为小型数据库的物理备份后的一 个逻辑辅助备份,也是不错的建议。对于越来越大的数据库,特别是TB级数据库和越来越多数据仓库的出现,EXP/IMP越来越力不从心了,这个时候,数据 库的备份都转向了RMAN和第三方工具。下面说明一下EXP/IMP的使用。
如何使exp的帮助以不同的字符集显示:set nls_lang=simplified chinese_china.zhs16gbk,通过设置环境变量,可以让exp的帮助以中文显示,如果set nls_lang=American_america.字符集,那么帮助就是英文的了

程序代码EXP的所有参数(括号中为参数的默认值):
USERID        用户名/口令      如: USERID=duanl/duanl     
FULL          导出整个数据库 (N)
BUFFER        数据缓冲区的大小        
OWNER        所有者用户名列表,你希望导出哪个用户的对象,就用owner=username
FILE           输出文件 (EXPDAT.DMP)   
TABLES        表名列表 ,指定导出的table名称,如:TABLES=table1,table2
COMPRESS     导入一个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 行 (0) 的进度
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)         
COMMIT        提交数组插入 (N)
ROWS     导入数据行 (Y)      
PARFILE       参数文件名
LOG       屏幕输出的日志文件  
CONSTRAINTS   导入限制 (Y)
DESTROY   覆盖表空间数据文件 (N)
INDEXFILE 将表/索引信息写入指定的文件
SKIP_UNUSABLE_INDEXES   跳过不可用索引的维护 (N)
ANALYZE   执行转储文件中的 ANALYZE 语句 (Y)
FEEDBACK 显示每 x 行 (0) 的进度
TOID_NOVALIDATE   跳过指定类型 id 的校验
FILESIZE 各转储文件的最大尺寸
RECALCULATE_STATISTICS 重新计算统计值 (N)
下列关键字仅用于可传输的表空间
TRANSPORT_TABLESPACE 导入可传输的表空间元数据 (N)
TABLESPACES 将要传输到数据库的表空间
DATAFILES 将要传输到数据库的数据文件
TTS_OWNERS 拥有可传输表空间集中数据的用户
关于增量参数的说明:exp/imp的增量并不是真正意义上的增量,所以最好不要使用。


使用方法:
Exp parameter_name=value or Exp parameter_name=(value1,value2……)
只要输入参数help=y就可以看到所有帮助.

EXP常用选项
1.FULL,这个用于导出整个数据库,在ROWS=N一起使用时,可以导出整个数据库的结构。例如:
exp userid=test/test file=./db_str.dmp log=./db_str.log full=y rows=n compress=y direct=y
2. 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
3.BUFFER和FEEDBACK,在导出比较多的数据时,我会考虑设置这两个参数。例如:
exp userid=test/test file=yw97_2003.dmp log=yw97_2003_3.log feedback=10000 buffer=100000000 tables=WO4,OK_YT
4.FILE和LOG,这两个参数分别指定备份的DMP名称和LOG名称,包括文件名和目录,例子见上面。
5.COMPRESS参数不压缩导出数据的内容。用来控制导出对象的storage语句如何产生。默认值为Y,使用默认值,对象的存储语句的init extent等于当前导出对象的extent的总和。

推荐使用COMPRESS=N。
6. FILESIZE该选项在8i中可用。如果导出的dmp文件过大时,最好使用FILESIZE参数,限制文件大小不要超过2G。如:
exp userid=duanl/duanl file=f1,f2,f3,f4,f5 filesize=2G owner=scott
这样将创建f1.dmp, f2.dmp等一系列文件,每个大小都为2G,如果导出的总量小于10G
EXP不必创建f5.bmp.

IMP常用选项
1、FROMUSER和TOUSER,使用它们实现将数据从一个SCHEMA中导入到另外一个SCHEMA中。例如:假设我们做exp时导出的为test的对象,现在我们想把对象导入用户:
imp userid=test1/test1 file=expdat.dmp fromuser=test1 touser=test1
2、IGNORE、GRANTS和INDEXES,其中IGNORE参数将忽略表的存在,继续导入,这个对于需要调整表的存储参数时很有用,我们可以先根据实际情况用合理的存储参数建好表,然后

直接导入数据。而GRANTS和INDEXES则表示是否导入授权和索引,如果想使用新的存储参数重建索引,或者为了加快到入速度,我们可以考虑将INDEXES设为N,而GRANTS一般都是Y

。例如:imp userid=test1/test1 file=expdat.dmp fromuser=test1 touser=test1 indexes=N

表空间传输
     表空间传输是8i新增加的一种快速在数据库间移动数据的一种办法,是把一个数据库上的格式数据文件附加到另外一个数据库中,而不是把数据导出成Dmp文件,这在有些时

候是非常管用的,因为传输表空间移动数据就象复制文件一样快。
关于传输表空间有一些规则,即:
·源数据库和目标数据库必须运行在相同的硬件平台上。
·源数据库与目标数据库必须使用相同的字符集。
·源数据库与目标数据库一定要有相同大小的数据块
·目标数据库不能有与迁移表空间同名的表空间
·SYS的对象不能迁移
·必须传输自包含的对象集
·有一些对象,如物化视图,基于函数的索引等不能被传输
可以用以下的方法来检测一个表空间或一套表空间是否符合传输标准:
exec sys.dbms_tts.transport_set_check(‘tablespace_name’,true);
select * from sys.transport_set_violation;
如果没有行选择,表示该表空间只包含表数据,并且是自包含的。对于有些非自包含的表空间,如数据表空间和索引表空间,可以一起传输。
以下为简要使用步骤,如果想参考详细使用方法,也可以参考ORACLE联机帮助。
1.设置表空间为只读(假定表空间名字为APP_Data 和APP_Index)
alter tablespace app_data read only;
alter tablespace app_index read only;
2.发出EXP命令
SQL>host exp userid=”””sys/password as sysdba”””
transport_tablespace=y tablespace=(app_data, app_index)
以上需要注意的是
·为了在SQL中执行EXP,USERID必须用三个引号,在UNIX中也必须注意避免“/”的使用
·在816和以后,必须使用sysdba才能操作
·这个命令在SQL中必须放置在一行(这里是因为显示问题放在了两行)
3.拷贝数据文件到另一个地点,即目标数据库
   可以是cp(unix)或copy(windows)或通过ftp传输文件(一定要在bin方式)
4.把本地的表空间设置为读写
5.在目标数据库附加该数据文件
imp file=expdat.dmp userid=”””sys/password as sysdba””” transport_tablespace=y “datafile=(c:\temp\app_data,c:\temp\app_index)”
6.设置目标数据库表空间为读写
alter tablespace app_data read write;
alter tablespace app_index read write;

优化EXP/IMP的方法:
     当需要exp/imp的数据量比较大时,这个过程需要的时间是比较长的,我们可以用一些方法来优化exp/imp的操作。
exp:使用直接路径 direct=y
oracle会避开sql语句处理引擎,直接从数据库文件中读取数据,然后写入导出文件.
可以在导出日志中观察到: exp-00067: table xxx will be exported in conventional path
     如果没有使用直接路径,必须保证buffer参数的值足够大.
     有一些参数于direct=y不兼容,无法用直接路径导出可移动的tablespace,或者用query参数导出数据库子集.
     当导入导出的数据库运行在不同的os下时,必须保证recordlength参数的值一致.

imp:通过以下几个途径优化
1.避免磁盘排序
将sort_area_size设置为一个较大的值,比如100M
2.避免日志切换等待
增加重做日志组的数量,增大日志文件大小.
3.优化日志缓冲区
比如将log_buffer容量扩大10倍(最大不要超过5M)
4.使用阵列插入与提交
commit = y
注意:阵列方式不能处理包含LOB和LONG类型的表,对于这样的table,如果使用commit = y,每插入一行,就会执行一次提交.
5.使用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                ZHS16GBK
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_COMP                        BINARY
NLS_NCHAR_CHARACTERSET          ZHS16GBK
NLS_RDBMS_VERSION               8.1.7.4.1
NLS_CHARACTERSET:ZHS16GBK是当前数据库的字符集。

我们再来查看客户端的字符集信息:
客户端字符集的参数NLS_LANG=_< territory >.
language:指定oracle消息使用的语言,日期中日和月的显示。
Territory:指定货币和数字的格式,地区和计算星期及日期的习惯。
Characterset:控制客户端应用程序使用的字符集。通常设置或等于客户端的代码页。或者对于unicode应用设为UTF8。
在windows中,查询和修改NLS_LANG可在注册表中进行:
HKEY_LOCAL_MACHINE\SOFTWARE\Oracle\HOMExx\
xx指存在多个Oracle_HOME时的系统编号。

在unix中:
$ env|grep NLS_LANG
NLS_LANG=simplified chinese_china.ZHS16GBK

修改可用:
$ export NLS_LANG=AMERICAN_AMERICA.UTF8

通常在导出时最好把客户端字符集设置得和数据库端相同。当进行数据导入时,主要有以下两种情况:
(1)     源数据库和目标数据库具有相同的字符集设置。
这时,只需设置导出和导入端的客户端NLS_LANG等于数据库字符集即可。
(2)     源数据库和目标数据库字符集不同。
     先将导出端客户端的NLS_LANG设置成和导出端的数据库字符集一致,导出数据,然后将导入端客户端的NLS_LANG设置成和导出端一致,导入数据,这样转换只发生在数据库端

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

不同版本的EXP/IMP问题
     一般来说,从低版本导入到高版本问题不大,麻烦的是将高版本的数据导入到低版本中,在Oracle9i之前,不同版本Oracle之间的EXP/IMP可以通过下面的方法来解决:
1、在高版本数据库上运行底版本的catexp.sql;
2、使用低版本的EXP来导出高版本的数据;
3、使用低版本的IMP将数据库导入到低版本数据库中;
4、在高版本数据库上重新运行高版本的catexp.sql脚本。
但在9i中,上面的方法并不能解决问题。如果直接使用低版本EXP/IMP会出现如下错误:
EXP-00008: orACLE error %lu encountered
orA-00904: invalid column name
这已经是一个公布的BUG,需要等到Oracle10.0才能解决,BUG号为2261722,你可以到METALINK上去查看有关此BUG的详细信息。
BUG归BUG,我们的工作还是要做,在没有Oracle的支持之前,我们就自己解决。在Oracle9i中执行下面的SQL重建exu81rls视图即可。
Create or REPLACE view exu81rls
(objown,objnam,policy,polown,polsch,polfun,stmts,chkopt,enabled,spolicy)
AS select u.name, o.name, r.pname, r.pfschma, r.ppname, r.pfname,
decode(bitand(r.stmt_type,1), 0,'', 'Select,')
|| decode(bitand(r.stmt_type,2), 0,'', 'Insert,')
|| decode(bitand(r.stmt_type,4), 0,'', 'Update,')
|| decode(bitand(r.stmt_type,8), 0,'', 'Delete,'),
r.check_opt, r.enable_flag,
DECODE(BITAND(r.stmt_type, 16), 0, 0, 1)
from user$ u, obj$ o, rls$ r
where u.user# = o.owner#
and r.obj# = o.obj#
and (uid = 0 or
uid = o.owner# or
exists ( select * from session_roles where role='Select_CATALOG_ROLE')
)
/
grant select on sys.exu81rls to public;
/

可以跨版本的使用EXP/IMP,但必须正确地使用EXP和IMP的版本:
1、总是使用IMP的版本匹配数据库的版本,如:要导入到817中,使用817的IMP工具。
2、总是使用EXP的版本匹配两个数据库中最低的版本,如:从9201往817中导入,则使用817版本的EXP工具。

=====================================

导入注意事项:
 (1) 数据库对象已经存在
  一般情况, 导入数据前应该彻底删除目标数据下的表, 序列, 函数/过程,触发器等; 
  数据库对象已经存在, 按缺省的imp参数, 则会导入失败
  如果用了参数ignore=y, 会把exp文件内的数据内容导入
  如果表有唯一关键字的约束条件, 不合条件将不被导入
  如果表没有唯一关键字的约束条件, 将引起记录重复
 (2) 数据库对象有主外键约束
         不符合主外键约束时, 数据会导入失败
         解决办法: 先导入主表, 再导入依存表
  disable目标导入对象的主外键约束, 导入数据后, 再enable它们

 

(3)  权限不够
  如果要把A用户的数据导入B用户下, A用户需要有imp_full_database权限
 (4)  导入大表( 大于80M ) 时, 存储分配失败
         默认的EXP时, compress = Y, 也就是把所有的数据压缩在一个数据块上.
         导入时, 如果不存在连续一个大数据块, 则会导入失败.
  导出80M以上的大表时, 记得compress= N, 则不会引起这种错误.
 (5) imp和exp使用的字符集不同
       如果字符集不同, 导入会失败, 可以改变unix环境变量或者NT注册表里NLS_LANG相关信息.
       导入完成后再改回来.
 (6) imp和exp版本不能往上兼容
 imp可以成功导入低版本exp生成的文件, 不能导入高版本exp生成的文件

使用方法:
 例题格式及说明:
 1.普通数据库全部导出和导入
  exp 用户/密码@dbName file=路径.dmp full=y  --还有其他的参数,看需要进行填写
  $ exp user/pwd file=/dir/xxx.dmp log=xxx.log full=y commit=y ignore=y  --全部导出
  $ imp user/pwd file=/dir/xxx.dmp log=xxx.log fromuser=dbuser touser=dbuser2 --全部导入
 
 2.指定用户全部导出
  /home/oracle/product/9.2.0.4/bin/exp userid=用户/密码    --说明:本地的数据库登入(可以指定其他数据库,则需添加@dbName)
   owner=导出的用户名 file=导出路径存放目录.dmp log=导出的日志信息.log  --主要:这是不能使用full=y或则会出错(默认该用户全导出)
 
  3.文件参数导出
  $ exp parfile=username.par // 在参数文件中输入所需的参数
   参数文件username.par 内容
   userid=username/userpassword
   buffer=8192000
   compress=n
   grants=y
   file=/oracle/test.dmp
   full=y
  4.制定表导出(分区表导出及条件表导出)
   $ exp user/pwd file=/dir/xxx.dmp log=xxx.log tables=table1,table2 --或tables(table1,table2,.....)
   $ exp user/pwd file=/dir/xxx.dmp log=xxx.log tables=(T1: table1,T2: table2,.....) --T1是分区表
   $ exp scott/tiger tables=emp query=\"where job=\'salesman\' and sal\<1600\" file=/directory/scott2.dmp 或根据参数文件进行导出
 
  5.导入(一张或多张表)
   $ imp user/pwd file=/dir/xxx.dmp log=xxx.log tables=(table1,table2) fromuser=dbuser
   touser=dbuser2 commit=y ignore=y
   $ imp user/pwd file=/dir/xxx.dmp log=xxx.log fromuser=dbuser touser=dbuser2
   commit=y ignore=y
 
 6.只导出数据对象不导出数据
  $ exp user/pwd file=/dir/xxx.dmp log=xxx.log owner=user rows=n --rows=n/y说明是否导出数据行
 
 7.分割多个文件导出和导入
  $ exp user/pwd file=1.dmp,2.dmp,3.dmp,… filesize=1000m log=xxx.log full=y
  $ imp user/pwd file=1.dmp,2.dmp,3.dmp,… filesize=1000m tables=xxx fromuser=dbuser
   touser=dbuser2 commit=y ignore=y
 
 8.增量导出和导入
  a.完全增量导出(inctype=complete) // 备份整个数据库
   $ exp user/pwd file=/dir/xxx.dmp log=xxx.log inctype=complete
   b.增量型增量导出 导出上一次备份后改变的数据(inctype=incremental)。
   $ exp user/pwd file=/dir/xxx.dmp log=xxx.log inctype=incremental
   c.累计型增量导出(Cumulative) 只导出自上次"完全"导出之后数据库中变化的信息。
   $ exp user/pwd file=/dir/xxx.dmp log=xxx.log inctype=cumulative
   d.增量导入:
   $ imp usr/pwd FULL=y inctype=system/restore/inctype --(SYSTEM: 导入系统对象,RESTORE: 导入所有用户对象)
 
 9.使用sysdba进行导出和导入
  1. 命令行方式:  
                      A: Windows平台:      
                         C:\> exp as sysdba" 
 
 10.表空间传输(建议: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 datafiles=(“c:\app_data.dbf,c:\app_index.dbf”)
     tablespaces=app_data,app_index tts_owners=hr,oe
   6.设置目标数据库表空间为读写
    $ alter tablespace app_data read write;
    $ alter tablespace app_index read write;
 11.优化IMP/EXP的速度(修改参数配置文件)

 

EXP:
   加大large_pool_size,可以提高exp 的速度
   采用直接路径的方式(direct=y),数据不需要经过内存进行整合和检查.
   设置较大的buffer,如果导出大对象,小buffer 会失败。
   export文件不在ORACLE 使用的驱动器上,不要export到NFS 文件系统
   UNIX环境:用管道模式直接导入导出来提高imp/exp 的性能
  IMP:
   建立一个indexfile,在数据import完成后在建立索引
   将import 文件放在不同的驱动器上
   增加DB_BLOCK_BUFFERS
   增加LOG_BUFFER
   用非归档方式运行ORACLE:ALTER DATABASE NOARCHIVELOG;
   建立大的表空间和回滚段,OFFLINE 其他回滚段,回滚段的大小为最大表的1/2
   使用 COMMIT=N
   使用ANALYZE=N
   单用户模式导入
   UNIX环境:用管道模式直接导入导出来提高imp/exp 的性能
    
 12.通过unix/Linux PIPE管道加快exp/imp速度
    步骤如下:
    通过管道导出数据:
  1.通过mknod -p 建立管道
   $ mknod /home/exppipe p // 在目录/home下建立一个管道exppipe注意参数p
  2.通过exp 和gzip 导出数据到建立的管道并压缩
   $ exp test/test file=/home/exppipe & gzip < /home/exppipe > exp.dmp.gz
   $ exp test/test tables=bitmap file=/home/newsys/test.pipe &
    gzip < /home/newsys/test.pipe > bitmap.dmp.gz
  3.导出成功完成之后删除建立的管道
   $ rm -rf /home/exppipe
  4.shell脚本可以这样写(我只是写主要的)
   unix下:
    mkfifo /home/exp.pipe
    chmod a+rw exp.pipe
    compress < exp.pipe > exp.dmp.Z &
     su -u oracle -c "exp userid=ll/ll file=/home/exp.pipe full=y buffer=20000000"
    rm exp.pipe
   linux下:
    mknod /home/exppipe p
    $ imp test/test file=/home/exppipe fromuser=test touser=macro &
     gunzip < exp.dmp.gz > /home/exppipe
    $ rm –fr /home/exppipe

分享到:
评论

相关推荐

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

    Oracle 数据库的 EXP/IMP 工具是数据库管理员(DBA)进行数据迁移、备份和恢复的重要工具。本文将详细介绍这两个工具的使用方法。 一、导出工具 EXP 1. EXP 是一个操作系统级别的可执行文件,通常位于 ORACLE_HOME...

    exp/imp2导入导出

    通过对 Oracle 表空间创建命令的分析以及对 exp/imp2 导入导出工具的介绍,我们可以看到,在 Oracle 数据库管理中,合理配置表空间属性和灵活运用备份恢复工具对于保障数据的安全性和可靠性至关重要。希望本文能帮助...

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

    本文将深入探讨Oracle数据库中使用exp/imp工具进行逻辑增量备份的方法及其恢复策略。 1一、实现需求 在Oracle数据库环境中,确保数据安全性和可用性是关键。逻辑增量备份的主要目标是在最小化系统停机时间和资源...

    Oracle expimp,备份或导入时注意的事项

    Oracle exp/imp 是Oracle数据库系统提供的两个实用工具,用于数据的备份和恢复。exp(Export)用于导出数据库中的对象和数据,而imp(Import)则用于将这些导出的数据导入到另一个数据库中。在实际操作中,由于各种...

    Oracle 19c 备份恢复-导入导出

    Oracle 19c 备份恢复-导入导出是指使用 Oracle 数据库提供的工具 exp 和 imp 实现数据库的备份恢复和数据的导入导出。本文将详细介绍 Oracle 19c 备份恢复-导入导出的基本命令、工作方式、模式、选项和高级选项。 ...

    oracle数据库exp_imp命令详解[参考].pdf

    exp 命令用于将数据库中的数据导出到文件中,而 imp 命令用于将文件中的数据导入到数据库中。 Oracle 数据库备份方法 Oracle 数据库有两类备份方法:物理备份和逻辑备份。物理备份方法实现数据库的完整恢复,但...

    oracle exp imp详解

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

    oracle导入导出(imp,exp本机或异机恢复)-详细笔记文档总结

    Oracle 导入导出(imp,exp 本机或异机恢复) Oracle 的数据库导入导出(imp/exp)是数据库管理员经常使用的两个命令,它们分别用于数据库的导出和导入。本文档总结了 Oracle 数据库的完全导入导出、imp 和 exp 命令...

    Oracle expimp导出导入命令及数据库备份很详细.doc

    Oracle的expimp工具是Oracle数据库管理系统中用于数据迁移和备份的关键组件。它们分别代表了数据导出和导入的功能,能够帮助管理员将数据从一个数据库移动到另一个数据库,或者创建数据库的备份副本。以下是对这两个...

    oracleClient安装包exp和imp文件.zip

    在Oracle环境中,"exp"和"imp"是两个关键的实用程序,用于数据的导出(export)和导入(import)。在这个"oracleClient安装包exp和imp文件.zip"压缩包中,我们主要关注的是这两个工具以及它们在Oracle客户端11.2....

    Oracle_exp_imp导出导入命令及数据库备份

    Oracle数据库的备份与恢复是数据库管理中的重要环节,Oracle提供了内置的工具——exp(导出)和imp(导入)命令,用于实现这一目的。这两个命令是Oracle早期版本中用于数据备份和恢复的主要方法,虽然在现代Oracle版本中...

    oracle命令 exp&imp命令详解

    在Oracle数据库管理中,数据的导入和导出是常见的操作,这通常涉及到exp和imp这两个命令。这两个命令允许用户将数据库对象(如表、索引、存储过程等)及其数据从一个数据库环境转移到另一个,或者进行数据备份和恢复...

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

    在Oracle 11g版本中,`imp.exe`和`exp.exe`是两个非常重要的工具,它们分别用于数据库导入和导出操作。这两个工具是Oracle Data Pump的一部分,提供高效的数据迁移和备份恢复功能。 一、imp.exe(数据库导入工具) ...

    oracle 常用的备份方式及备份策略

    EXP/IMP 逻辑备份可以跨版本使用,例如可以将 Oracle 11g 的备份文件导入到 Oracle 12c 中。 OS 备份 OS 备份是指备份操作系统文件,例如数据文件、日志文件等。 冷备份 冷备份是指数据库关闭时进行备份,冷备份...

Global site tag (gtag.js) - Google Analytics