oracle数据库拷贝迁移(oracle11exp表不全问题解决)

Oracle有两类备份方式:物理备份和逻辑备份,物理备份在此不做详细介绍,本文只介绍逻辑备份EXP/IMP过程。

1)       EXP导出

在源产品环境命令行sql*plus命令行中或者在DOS(命令行)中,输入以下命令:

exp 用户名 / 用户密码 buffer=64000      

file=路径(要先建好路径)\***.dmp

log=路径(要先建好路径)\***.log

owner=需要导出表的所有者用户名列表

示例如下:

1. exp exportal_was/exportal_was buffer=64000

2.  file=/u01/app/oradata/portal/users01.dmp  

3.  log=/u01/app/oradata/portal/users01.log

4. owner=exportal_was  

 

执行完毕后即可在对应的路径找到对应的数据库备份dmp文件。

注:Oracle 11g默认对空表不分配segment,故使用exp导出Oracle11g数据库时,空表不会导出,如果源产品环境数据库是oracle11版本,执行上述导出命令之前需要先进行如下处理,在sql*plus中用以下这句查找空表:

select 'altertable ' || table_name || ' allocate extent(size 64k);'

fromuser_tables

wheretable_name not in

(selectsegment_name from user_segments where segment_type = 'TABLE');

把查询结果导出,执行导出的语句,执行完后即可执行上面exp导出语句。

2)       IMP导入

将exp命令导出的dmp文件拷贝至目标产品数据库环境中,在目标产品数据库环境命令行sql*plus命令行中或者在DOS(命令行)中,输入以下命令:

imp 用户名/用户密码

file=路径/(导出的文件).dmp

fromuser=源数据库中所有人用户名列表 touser=导入的用户名列表

示例如下:

1.    imp exportal/exportal   

2.    file=/u01/app/oradata/portal/users01.dmp  

3.    fromuser=exportal_was touser=exportal   

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值