1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > oracle impdp使用 Oracle expdp / impdp 用法详解

oracle impdp使用 Oracle expdp / impdp 用法详解

时间:2021-10-31 03:10:47

相关推荐

oracle impdp使用 Oracle expdp / impdp 用法详解

一 关于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 做业相关的开销可能超过并行线程的效益,并所以而下降性能。并行方式只有在表的数量多于并行值而且表很大时才是有效的。

数据库监控

您还能够从数据库视图得到关于运行的 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/cuc@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/cuc@cucf as sysdba' schemas=sybj directory=DATA_PUMP_DIR dumpfile=aa.dmp logfile=aa.log version=10.2.0.1.0

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。