oracle expdp、impdp导入从原表空间更换到其他表空间 ----导入到另个表空间测试
数据泵:
属于逻辑备份的范围,将数据转储为一个dmp文件。
优点:支持并发多线程方式,性能显著提高,比exp/imp实用工具相比,导出提高了10倍左右,导入提高了5倍左右。
能根据备份时收集的元数据,自动创建用户、表对象,支持作业、表空间备份方式。
缺点:需要在服务器上面执行 创建目录 授权(可以远程导出)
(exp不支持字段类型,BINARY_DOUBLE双精度二进制浮点类型
(expdp不支持网络链来加载long"保存文本类型"列,支持本地
测试:oracle expdp、impdp导入从原表空间更换到其他表空间
数据泵:
导入到另个表空间测试:
默认dump文件放的位置
SQL>
OWNER
------------------------------ ----------------------------
SYS
SQL>conn / as sysdba
创建一个新dump文件位置
SQL> create directory dump_dir1 AS 'E:\app\Administrator\oradata\dump_dir';
目录已创建。
SQL> select * from dba_directories where directory_name='DUMP_DIR1';
OWNER
------------------------------ ----------------------------
SYS
正常这个目录只有dba 和system高级用户可以使用
普通用户操作报如下错误:
E:\app\Administrator\product\11.2.0\dbhome_1\BIN>expdp s/s directory=dump_dir1 dumpfile=ss1.dmp
content=data_only
Export: Release 11.2.0.1.0 - Production on 星期三 1月 16 10:32:49 2013
Copyright (c) 1982, 2009, Oracle and/or its affiliates.
连接到: Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
ORA-39002: 操作无效
ORA-39070: 无法打开日志文件。
ORA-39087: 目录名 DUMP_DIR1 无效
把dump目录授权给某个用户
SQL> conn / as sysdba
已连接。
SQL> grant read,write on directory
授权成功。
再次导出:
E:\app\Administrator\product\11.2.0\dbhome_1\BIN>expdp s/s directory=dump_dir1 dumpfile=ss1.dmp
content=data_only
Export: Release 11.2.0.1.0 - Production on 星期三 1月 16 10:35:35 2013
Copyright (c) 1982, 2009, Oracle and/or its affiliates.
连接到: Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
启动 "S"."SYS_EXPORT_SCHEMA_01":
正在使用 BLOCKS 方法进行估计...
处理对象类型 SCHEMA_EXPORT/TABLE/TABLE_DATA
....
常用的参数:
directory=dump_dir1
directory=dump_dir1 logfile=dump_dir1:aaa.log
directory=dump_dir1 dumpfile=dump_dir1:aaa.dmp
expdp s/s directory=dump_dir1 dumpfile=sas1.dmp logfile=aa.log
schemas=scott
TABLES=emp,dept
query='WHERE deptno=20'
TABLESPACES=temp,example
FULL=y
content=all/metadata_only/data_only
impdp
REMAP_SCHEMA=scott:system
TABLESPACES=example
TABLE_EXISTS_ACTION
table_exists_action
E: > expdp s/s schemas=s directory=dump_dir1 dumpfile=EXPDP.DMP logfile=EXPDP.LOG
E: > impdp EXPDPTEST/EXPDPTEST directory=dump_dir1 dumpfile=c.dmp REMAP_SCHEMA=s:EXPDPTEST REMAP_TABLESPACE=USERS:C
这个C表空间创建:
create tablespace C datafile 'E:\app\Administrator\oradata\orcl2\C' size 50M AUTOEXTEND ON NEXT 5M MAXSIZE UNLIMITED;
要给足空间
要不然在导入的时候超过空间报错:
ORA-39171: 作业出现可恢复的等待。
ORA-01659: 无法分配超出 2 的 MINEXTENTS (在表空间 C 中)
SQL> conn EXPDPTEST/EXPDPTEST
已连接。
SQL> select owner,table_name,tablespace_name from dba_tables where table_name='BD_PROD_INFO';
OWNER
------------------------------ ------------------------------------------------------------
EXPDPTEST
S
EXPDP -help解释
IMPDP -help解释
create directory dp_dir1 as 'E:\oracle\directory';
grant read, write on directory dp_dir1 to smart;
expdp smart/smart@orcl schemas=smart dumpfile=expdp.dmp DIRECTORY=dp_dir1;
impdp alarm/alarm@orcl directory=dp_dir1 dumpfile=expdp.dmp remap_schema=smart:alarm remap_tablespace=smart_data:alarm_data;