Oracle服务器端数据导出导入

一、数据操作前的准备
(1).创建逻辑目录
登录数据库服务器,登录数据库(最好是dba账号)
$ sqlplus umcc/umcc123

SQL> create directory UMCC_DMP as '/export/home/umcc/dmp'; --创建目录映射(逻辑目录)
SQL> grant read,write on directory UMCC_DMP to public; --将目录映射授权
SQL> select * from dba_directories; --查看目录映射

(2).创建日志文件并授权
$ vi import.log
$ chmod 777 ./import.log

此步骤导出与导入前都需要先确认。


二、数据导出
数据导出,输入如下命令:
$ expdp DIRECTORY=UMCC_DMP DUMPFILE=bsn01.dmp TABLES=umcc.T_PROCESS,umcc.T_REPORT_CONDITION_TEMPLATE,umcc.T_REPORT_CUSTOM,umcc.REPORT_INFORMIXDB_VDEAL,umcc.T_NETWORKVIEW_UNIT_RELATION,umcc.T_TOPO_NODE_VIEW LOGFILE=portal.log

执行,然后输入账号、密码

参数解析:
DIRECTORY 指定逻辑目录。
DUMPFILE  指定数据文件名。
TABLES    指定导出那些表,表用英文逗号分隔。
LOGFILE   指定日志文件。
CONTENT   指定要导出的内容。
该选项用于指定要导出的内容,默认值为ALL。
CONTENT={ALL | DATA_ONLY | METADATA_ONLY}
当设置CONTENT为ALL时,将导出对象定义及其所有数据。为DATA_ONLY时,只导出对象数据。为METADATA_ONLY时,只导出对象定义。

expdp zftang/zftang@zftang directory=dmp  dumpfile=test.dmp content=metadata_only --只导出对象定义
expdp zftang/zftang@zftang directory=dmp  dumpfile=test.dmp content=data_only --导出所有数据


三、数据导入
数据导入可以指定导入那些表和所有表数据导入。

方法一:数据文件里面所有表都导入。
impdp umcc/umcc123 DIRECTORY=UMCC_DMP REMAP_TABLESPACE=TS_UMCC:TS_ITMP DUMPFILE=bsn01.dmp table_exists_action=truncate LOGFILE=import.log

方法二:指定数据文件里的表导入。
impdp umcc/umcc123 directory=UMCC_DMP REMAP_TABLESPACE=TS_UMCC:TS_ITMP dumpfile=bsn01.dmp table_exists_action=truncate TABLES=T_PROCESS,T_REPORT_CONDITION_TEMPLATE,T_REPORT_CUSTOM,REPORT_INFORMIXDB_VDEAL,T_NETWORKVIEW_UNIT_RELATION LOGFILE=import.log


参数解析:
REMAP_SCHEMA      用户切换。REMAP_SCHEMA当你从A用户导出的数据,想要导入到B用户中去,就使用这个 REMAP_SCHEMA=A:B
REMAP_TABLESPACE  表空间切换。数据库对象本来存在于tbs_a表空间,换到tbs_b,就用这个 REMAP_TABLESPACE=tbs_a:tbs_b 所有tbs_a中的对象都会建在tbs_b表空间中。

TABLE_EXISTS_ACTION   表一存在数据处理方式。
使用imp进行数据导入时,若表已经存在,要先drop掉表,再进行导入。
而使用impdp完成数据库导入时,若表已经存在,有四种的处理方式:
1) skip:默认操作;
2) replace:先drop表,然后创建表,最后插入数据;
3) append:在原来数据的基础上增加数据;
4) truncate:先truncate,然后再插入数据。

使用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)按用户导
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;


五、还原数据
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

参考:
http://www.cnblogs.com/luluping/archive/2010/03/16/1687093.html

猜你喜欢

转载自ahomeeye.iteye.com/blog/2047957