expdp/impdp 数据库迁移详细过程


下面介绍如果利用数据泵(expdp/impdp)的方式进行数据库的迁移

一.源数据源上操作

1.查出你要导出的用户下面的表空间

select distinct  tablespace_name from dba_segments where owner='用户名'


2.检查DB上是否有DUMP_DIR目录,没有就创建并授权,具体命令为下:

CREATE OR REPLACE DIRECTORY DUMP_DIR AS 'E:\app\Administrator\dump_dir';
GRANT READ, WRITE ON DIRECTORY DUMP_DIR TO system;
GRANT READ, WRITE ON DIRECTORY DUMP_DIR TO public;
GRANT READ, WRITE ON DIRECTORY DUMP_DIR TO user_xxx;   #这里的user_xxx指你要导出的用户名

3.导出源数据库上schema,具体命令如下:

expdp 用户名/密码@数据库 schemas=模式 directory=DUMP_DIR dumpfile=2018_03_15_xxxx.dmp  logfile=2018_03_15_xxx.log

各参数解释:

用户名:为你要导出的用户的用户名
密码:为你要导出的用户的密码
数据库:为你要导出的数据库实例名
模式:为你要导出的schema,这里就理解为你要导出的用户名
directory:即你刚才创建的DUMP目录,也就是说你将要导出的数据文件和日志文件存放在哪个目录下
dumpfile:导出的文件名字,这里文件名可以随便起
logfile:记录导出的日志,同样这里的log文件名可以随便起

详细的expdp的参数可参数:http://blog.youkuaiyun.com/shiyu1157758655/article/details/54966626

示例:
expdp dairy/oracle@foidndb schemas=dairy directory=DUMP_DIR dumpfile=2018_03_15_dairy.dmp  logfile=2018_03_15_dairy.log

二、目标数据库(即你要导入的数据库)

1.在目标数据库上创建源数据上查出的表空间,命令如下:

create tablespace xxxx datafile 'xxxx' size 32M autoextend on next 32M MAXSIZE UNLIMITED;

注意:如果导出的源数据比较大,则在这步骤应该对给表空间创建多个datfile


2.创建用户名,假如源数据库导出的用户是A,则你要在目标数据库上创建相应的用户A并且赋予相应的权限

注意:如果你源库上是A,你要导入到目标库上B用户下面也是可以的,利用remap这里就不介绍这种情况

3.目标库上创建DUMP_DIR,命令同上

CREATE OR REPLACE DIRECTORY DUMP_DIR AS 'E:\app\Administrator\dump_dir';
GRANT READ, WRITE ON DIRECTORY DUMP_DIR TO system;
GRANT READ, WRITE ON DIRECTORY DUMP_DIR TO public;
GRANT READ, WRITE ON DIRECTORY DUMP_DIR TO user_xxx;   #这里的user_xxx指你要导出的用户名

4.将在源数据库上备份出来的文件上传到上一步骤中创建的DUMP_DIR 相应的目录下

5.执行下面命令进行导入

impdp 用户名/密码@数据库 schemas=模式 directory=DUMP_DIR dumpfile=2018_03_15_xxxx.dmp  logifle=2018_03_15_xxx.log

6. 编译失效Objects
EXEC dbms_utility.compile_schema('PUBLIC',false);
EXEC dbms_utility.compile_schema('用户名',false);
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

雨花石~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值