Oracle - expdp、impdp导入从原表空间更换到其他表空间 ----导入到另个表空间测试

数据泵:
属于逻辑备份的范围,将数据转储为一个dmp文件。
优点:支持并发多线程方式,性能显著提高,比exp/imp实用工具相比,导出提高了10倍左右,导入提高了5倍左右。
能根据备份时收集的元数据,自动创建用户、表对象,支持作业、表空间备份方式。
缺点:需要在服务器上面执行 创建目录 授权(可以远程导出)
(exp不支持字段类型,BINARY_DOUBLE双精度二进制浮点类型 http://www.2cto.com/database/201202/119920.htmlnumber类型和浮点类型区别“number十进制,BINARY_DOUBLE二进制(比number效率高,速度快,占用空间小的优点.但版本兼容性不好)”)
(expdp不支持网络链来加载long"保存文本类型"列,支持本地  exp支持long的导出导入)

 

测试:oracleexpdp、impdp导入从原表空间更换到其他表空间

数据泵:

导入到另个表空间测试:

默认dump文件放的位置
SQL>  select * from dba_directories wheredirectory_name='DATA_PUMP_DIR';
 
OWNER                         DIRECTORY_NAME   DIRECTORY_PATH
---------------------------------------------------------- --------------------------------
SYS                           DATA_PUMP_DIR   E:\app\Administrator\admin\orcl1\dpdump\

SQL>conn / as sysdba

创建一个新dump文件位置
SQL> create directory dump_dir1 AS'E:\app\Administrator\oradata\dump_dir';

目录已创建。

SQL> select * from dba_directories wheredirectory_name='DUMP_DIR1';

OWNER                         DIRECTORY_NAME   DIRECTORY_PATH
---------------------------------------------------------- --------------------------------
SYS                           DUMP_DIR1    E:\app\Administrator\oradata\dump_dir


正常这个目录只有dba 和system高级用户可以使用
普通用户操作报如下错误:
E:\app\Administrator\product\11.2.0\dbhome_1\BIN>expdps/s directory=dump_dir1 dumpfile=ss1.dmp
content=data_only

Export: Release 11.2.0.1.0 - Production on 星期三 1月 16 10:32:492013

Copyright (c) 1982, 2009, Oracle and/or itsaffiliates.  All rights reserved.

连接到: Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 -Production
With the Partitioning, OLAP, Data Mining and Real ApplicationTesting options
ORA-39002: 操作无效
ORA-39070: 无法打开日志文件。
ORA-39087: 目录名 DUMP_DIR1 无效


把dump目录授权给某个用户
SQL> conn / assysdba
已连接。
SQL> grant read,write ondirectory  dump_dir1 to s;

授权成功。

再次导出:  OK了
E:\app\Administrator\product\11.2.0\dbhome_1\BIN>expdps/s directory=dump_dir1 dumpfile=ss1.dmp
content=data_only

Export: Release 11.2.0.1.0 - Production on 星期三 1月 16 10:35:352013

Copyright (c) 1982, 2009, Oracle and/or itsaffiliates.  All rights reserved.

连接到: Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 -Production
With the Partitioning, OLAP, Data Mining and Real ApplicationTesting options
启动 "S"."SYS_EXPORT_SCHEMA_01":  s/********directory=dump_dir1 dumpfile=ss1.dmp content=data_only
正在使用 BLOCKS 方法进行估计...
处理对象类型 SCHEMA_EXPORT/TABLE/TABLE_DATA
....


常用的参数:
directory=dump_dir1 ((必须指定目录对象参数且不能为空directory=dump_dir1)logfile/dumpfile在指定目录的基础上)
directory=dump_dir1 logfile=dump_dir1:aaa.log
directory=dump_dir1 dumpfile=dump_dir1:aaa.dmp
expdp s/s directory=dump_dir1 dumpfile=sas1.dmplogfile=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   更改owner
TABLESPACES=example   导入表空间
TABLE_EXISTS_ACTION   追加数据
table_exists_action   {skip是如果已存在表,则跳过并处理下一个对象;
      append是为表增加数据;
      truncate是截断表,然后为其增加新数据;
      replace是删除已存在表,重新建表并追加数据}


E: > expdp s/s schemas=s directory=dump_dir1dumpfile=EXPDP.DMP logfile=EXPDP.LOG
E: > impdp EXPDPTEST/EXPDPTEST directory=dump_dir1dumpfile=c.dmp REMAP_SCHEMA=s:EXPDPTESTREMAP_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 fromdba_tables where table_name='BD_PROD_INFO';

OWNER                         TABLE_NAME  TABLESPACE_NAME
------------------------------------------------------------------------------------------
EXPDPTEST                       BD_PROD_INFO  C
S                             BD_PROD_INFO  USERS

你可能感兴趣的:(#,Oracle)