oracleimpdp使⽤,Oracleexpdpimpdp⽤法详解
⼀ 关于expdp和impdp 使⽤EXPDP和IMPDP时应该注意的事项:
EXP和IMP是客户端⼯具程序,它们既能够在客户端使⽤,也能够在服务端使⽤。
EXPDP和IMPDP是服务端的⼯具程序,他们只能在ORACLE服务端使⽤,不能在客户端使⽤。
IMP只适⽤于EXP导出的⽂件,不适⽤于EXPDP导出⽂件;IMPDP只适⽤于EXPDP导出的⽂件,⽽不适⽤于EXP导出⽂件。
expdp或impdp命令时,可暂不指出⽤户名/密码@实例名 as ⾝份,⽽后根据提⽰再输⼊,如:
expdp schemas=scott dumpfile=expdp.dmp DIRECTORY=dpdata1;
1、建⽴逻辑⽬录,该命令不会在操做系统建⽴真正的⽬录,最好以system等管理员建⽴。
create directory dpdata1 as 'd:\test\dump';
2、查看管理理员⽬录(同时查看操做系统是否存在,由于Oracle并不关⼼该⽬录是否存在,若是不存在,则出错)
select * from dba_directories;
3、给scott⽤户赋予在指定⽬录的操做权限,最好以system等管理员赋予。
grant read,write on directory dpdata1 to scott;
4、导出数据
1)按⽤户导
expdp scott/tiger@orcl schemas=scott dumpfile=expdp.dmp DIRECTORY=dpdata1;
2)并⾏进程parallel
expdp scott/tiger@orcl directory=dpdata1 dumpfile=scott3.dmp parallel=40 job_name=scott3
3)按表名导
expdp scott/tiger@orcl TABLES=emp,dept dumpfile=expdp.dmp DIRECTORY=dpdata1;
4)按查询条件导
expdp scott/tiger@orcl directory=dpdata1 dumpfile=expdp.dmp Tables=emp query='WHERE deptno=20';
5)按表空间导
expdp system/manager DIRECTORY=dpdata1 DUMPFILE=tablespace.dmp TABLESPACES=temp,example;
6)导整个数据库
expdp system/manager DIRECTORY=dpdata1 DUMPFILE=full.dmp FULL=y;
5、还原数据
1)导到指定⽤户下
impdp scott/tiger DIRECTORY=dpdata1 DUMPFILE=expdp.dmp SCHEMAS=scott;
2)改变表的owner
impdp system/manager DIRECTORY=dpdata1 DUMPFILE=expdp.dmp TABLES=scott.dept REMAP
_SCHEMA=scott:system;
3)导⼊表空间
impdp system/manager DIRECTORY=dpdata1 DUMPFILE=tablespace.dmp TABLESPACES=example;
4)导⼊数据库
impdb system/manager DIRECTORY=dump_dir DUMPFILE=full.dmp FULL=y;
5)追加数据
impdp system/manager DIRECTORY=dpdata1 DUMPFILE=expdp.dmp SCHEMAS=system TABLE_EXISTS_ACTION
⼆ 附加说明 并⾏操做(PARALLEL)
您能够经过 PARALLEL 参数为导出使⽤⼀个以上的线程来显著地加速做业。每⼀个线程建⽴⼀个单独的转储⽂件,所以参数 dumpfile 应当拥有和并⾏度同样多的项⽬。您能够指定通配符做为⽂件名,⽽不是显式地输⼊各个⽂件名,例如:
expdp ananda/abc123 tables=CASES directory=DPDATA1 dumpfile=expCASES_%U.dmp parallel=4
job_name=Cases_Export
注意:dumpfile 参数拥有⼀个通配符 %U,它指⽰⽂件将按须要建⽴,格式将为expCASES_nn.dmp,其中nn 从 01 开始,⽽后按须要向上增长。
在并⾏模式下,状态屏幕将显⽰四个⼯做进程。(在默认模式下,只有⼀个进程是可见的)全部的⼯做进程同步取出数据,并在状态屏幕上显⽰它们的进度。
分离访问数据⽂件和转储⽬录⽂件系统的输⼊/输出通道是很重要的。不然,与维护 Data Pump 做业相关的开销可能超过并⾏线程的效益,并所以⽽下降性能。并⾏⽅式只有在表的数量多于并⾏值⽽且表很⼤时才是有效的。exists的用法
数据库监控
您还能够从数据库视图得到关于运⾏的 Data Pump 做业的更多信息。监控做业的主视图是 DBA_DATAPUMP_JOBS,它将告诉您在做业上有多少个⼯做进程(列 DEGREE)在⼯做。
另外⼀个重要的视图是 DBA_DATAPUMP_SESSIONS,当它与上述视图和 V$SESSION 结合时将给出主前台进程的会话 SID。
select sid, serial# from v$session s, dba_datapump_sessions d where s.saddr = d.saddr;
这条指令显⽰前台进程的会话。更多有⽤的信息能够从警报⽇志中得到。当进程启动时,MCP 和⼯做进程在警报⽇志中显⽰以下:
kupprdp:master process DM00 started with pid=23, OS id=20530 to execute - SYS.KUPM$MCP.MAIN('CASES_EXPORT',
'ANANDA'); kupprdp:worker process DW01 started with worker id=1, pid=24, OS id=20532 to execute -
SYS.KUPW$WORKER.MAIN('CASES_EXPORT', 'ANANDA'); kupprdp:worker process DW03 started with worker id=2, pid=25, OS id=20534 to execute - SYS.KUPW$WORKER.MAIN('CASES_EXPORT', 'ANANDA');
它显⽰为数据泵操做启动的会话的 PID。您能够⽤如下查询到实际的 SID:
select sid, program from v$session where paddr in (select addr from v$process where pid in (23,24,25));
PROGRAM 列将对应警报⽇志⽂件中的名称显⽰进程 DM (为主进程)或 DW (为⼯做进程)。若是⼀个⼯做进程使⽤了并⾏查询,好⽐说SID 23,您能够在视图 V$PX_SESSION 中看到它,并把它出来。它将为您显⽰从 SID 23 表明的⼯做进程中运⾏的全部并⾏查询会话:
select sid from v$px_session where qcsid = 23;
从视图 V$SESSION_LONGOPS 中能够得到其它的有⽤信息来预测完成做业将花费的时间。
select sid, serial#, sofar, totalwork from v$session_longops where opname = 'CASES_EXPORT' and sofar != totalwork;
列 totalwork 显⽰总⼯做量,该列的 sofar 数量被加和到当前的时刻 — 于是您能够⽤它来估计还要花多长时间。
三 oracle 10g 和11g的互相导⼊和导出 1) 能够⽤10g的client链接11个导出11g的数据库,便可导⼊10g 2)⽤expdp,impdp,如:
在11g服务器上,使⽤expdp命令备份数据
EXPDP USERID='SYS/cuc2009@cuc as sysdba' schemas=sybj directory=DATA_PUMP_DIR dumpfile=aa.dmp logfile=aa.log version=10.2.0.1.0
在10g服务器上,使⽤impdp命令恢复数据
准备⼯做:1.建库2.建表空间3.建⽤户并受权4.将aa.dmp拷贝到10g的dpdump⽬录下
IMPDP USERID='SYS/cuc2009@cucf as sysdba' schemas=sybj directory=DATA_PUMP_DIR dumpfile=aa.dmp logfile=aa.log version=10.2.0.1.0
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论