这篇文章主要介绍如何使用DataPump迁移Oracle数据库,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
之前测试过使用RMAN迁移Oracle数据库(Oracle11.2.0.1-Oracle11.2.0.4,Windows to Linux) 下面简单说下使用数据泵的方式如何迁移。
相对来说,确实比较简单,导出导入,但也可以分为两种方式,一个是按照业务用户来做导出,再个全库导出,不只是多了一个full=y,其他也有一些不同的,好,我们来看看
环境介绍,源端Windows2008 x64+Oracle11.2.0.1
目标端:Redhat6.7 x64+Oracle11.2.0.4
首先环境准备,也就是目标端环境准备,Linux下Oracle数据库安装及打最新补丁,此处忽略。
不管是全库导出导入还是按照业务用户方式,都需要提前创建表空间,尤其数据量比较大的,都需要提前创建好,这样也节约时间。 那么我们如何获取源库创建表空间的ddl呢?
如下语句会列出所有表空间的创建语句,请注意系统相关表空间大小,例如SYSTEM、USERS,有可能表空间比较大,会有多个数据文件。
set long 1000000
set pages 9999
select dbms_metadata.get_ddl('TABLESPACE',tablespace_name) from dba_tablespaces;
查询某一个表空间的DDL语句
select dbms_metadata.get_ddl('TABLESPACE','MYDB') from dual;
源端可以执行全库导出操作了,首先我们需要创建directory
create directory exp as 'd:\datapump'; --导出使用sys用户,无需赋权
expdp '/ as sysdba' directory=my_exp dumpfile=myexpdb%U.dmp logfile=myexpdb.log parallel=2 EXCLUDE=STATISTICS parfile=mypar.par
#mypar.par m注意可以排除系统用户及非OPEN用户 全库导出无需创建用户
FULL=Y
EXCLUDE=SCHEMA:"in (select username from dba_users where account_status<>'OPEN' or username in('SYS','SYSTEM'))"
下面就简单了,目标端就可以导入
注意:全库导出,导入时会导入role、DIRECTORY、TABLESPACE、CONTEXT等,我们可以选择排除
impdp \'/ as sysdba\' directory=exp dumpfile=myexpdb%U.dmp logfile=myimpdb01.log parallel=2 exclude=DIRECTORY exclude=role exclude=CONTEXT exclude=TABLESPACE
导入完成,收集统计信息
exec dbms_stats.GATHER_DATABASE_STATS(estimate_percent=>null);
那么如果只导出业务用户呢,我们需要创建用户,并且赋予相关权限
通过以下语句生成创建用户的语句(Oracle11g)
通过以下语句生成赋权限语句
导出语句类似如下:
expdp '/ as sysdba' directory=my_exp dumpfile=myexpdb%U.dmp logfile=myexpdb.log parallel=2 EXCLUDE=STATISTICS schema=mydb,test
导入语句:
impdp \'/ as sysdba\' directory=exp dumpfile=myexpdb%U.dmp logfile=myimpdb01.log parallel=2
收集数据库统计信息
当然,这需要停机时间,如果对于停机时间要求特别严格,建议使用OGG相关同步软件,rman增量备份也是可以一试的。
以上是“如何使用DataPump迁移Oracle数据库”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!