oracle 导出以开头的表,ORACLE expdp导出/导入以XX开头的所有表
场景:有2个oracle用户,userA默认表空间tablespaceA, userB默认表空间tablespaceB。现在需要将userA中的系统表(该用户表空间中以SYS开头的表)导出到userB中,将userB的系统表覆盖,但不覆盖userB的业务表。方法如下:导出userA用户schema中SYS开头的表,使用tables=SYS%expdpuserA/passworddirectory=
场景:有2个oracle用户,userA默认表空间tablespaceA, userB默认表空间tablespaceB。
现在需要将userA中的系统表(该用户表空间中以SYS开头的表)导出到userB中,将userB的系统表覆盖,但不覆盖userB的业务表。方法如下:
导出userA用户schema中SYS开头的表,使用tables=SYS%
expdpuserA/passworddirectory=TMP_BAKdumpfile=userA-170504-expdp-tab.dmplogfile=userA-170504-expdp-tab.logtables=SYS%
若只需导出某几张表,则使用tables=table1,table2
expdpuserA/passworddirectory=TMP_BAKdumpfile=userA-170504-expdp-tab02.dmplogfile=userA-170504-expdp-tab02.logtables=table1,table2
将导出的dmp文件导入到userB用户的schema中。
需要注意此处SCHEMA与表对应的TABLESPACE已经发生改变,并且原userB的表空间中已经存在SYS表。故导入时需要加上以下几个参数:
①remap_schema指定源SCHEMA与目的SCHEMA。
②remap_tablespace指定源TABLESPACE与目的TABLESPACE。
③table_exists_action=replace将重名表进行覆盖。
导入前注意先备份userB的数据,避免导出出错造成数据丢失。
expdpuserB/passworddirectory=TMP_BAKdumpfile=userB-170504-expdp.dmplogfile=userB-170504-expdp.log
正式将SYS开头的表导入userB用户中。
impdpuserB/passworddirectory=TMP_BAKdumpfile=userA-170504-expdp-tab.dmpremap_schema=userA:userBREMAP_TABLESPACE=tablespaceA:tablespaceBTABLE_EXISTS_ACTION=REPLACElogfile=userB-0504-impdp-tab.log
总结
如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐



所有评论(0)