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

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的导出导入)

 

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

数据泵:

导入到另个表空间测试:

默认dump文件放的位置
SQL>   select * from dba_directories where directory_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 where directory_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>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.  All rights reserved.

连接到: 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  dump_dir1 to s;

授权成功。

再次导出:  OK 了
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.  All rights reserved.

连接到: 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":  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.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    更改owner
TABLESPACES=example   导入表空间
TABLE_EXISTS_ACTION   追加数据
table_exists_action   {skip 是如果已存在表,则跳过并处理下一个对象;
      append是为表增加数据;
      truncate是截断表,然后为其增加新数据;
      replace是删除已存在表,重新建表并追加数据}


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                          TABLE_NAME  TABLESPACE_NAME
------------------------------ ------------------------------------------------------------
EXPDPTEST                        BD_PROD_INFO  C
S                              BD_PROD_INFO  USERS


EXPDP -help解释 http://blog.sina.com.cn/s/blog_bba8a5b40101a2mj.html
IMPDP -help解释 http://blog.sina.com.cn/s/blog_bba8a5b40101a2mt.html



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;


你可能感兴趣的:(数据库)