Oracle中exp,imp的TableSpace表空间问题

当用EXP导出表,其表的表空间和需要导入的表空间不一致时,有两种处理方法。

1.修改该表的表空间语句。

<wbr>如有表T1,所在表空间为USER。直接修改其表空间必须先删除此表数据,而且当有几百张表时,直接修改起来也是一件麻烦的事情。所以采用以下处理方法比较明智。</wbr>

step1:直接导出dump。

exp<wbr>&lt;username&gt;/&lt;</wbr> password >@servicename<wbr>file=&lt;filename.dmp&gt;<wbr></wbr></wbr> owner=ownername<wbr><span>rows</span><span>=y<wbr>tables=&lt;table1,table2&gt;</wbr></span></wbr>

step2:利用导出的dump,得到indexfile。<wbr></wbr>

imp<wbr>&lt;username&gt;/&lt;</wbr>password>@servicename<wbr>file=&lt;filename.dmp&gt;<wbr></wbr></wbr> indexfile<wbr>=<wbr>&lt;<span>index</span><span>.sql&gt;<wbr></wbr></span><span>full</span><span>=y<wbr></wbr></span></wbr></wbr>

step3:<wbr>利用EDIT工具快速修改tablespace语句并保存index.sql</wbr>

Find: 'REM<space>' Replace: <nothing>

Find: '"<source_tablespace>"' Replace: tablespace name

Find: '...' Replace: 'REM ...'

Find: 'CONNECT' Replace: 'REM CONNECT'

step4: 在目标数据库中执行index.sql

nbsp;sqlplus<wbr>&lt;username&gt;/&lt;</wbr>password>@servicename<wbr></wbr>@index.sql<wbr><wbr></wbr></wbr></span

step5:把step1导出的dump导入到目标数据库,step4只是创建了表结构

imp <username>/<password>@servicename file=<filename.dmp> fromuser=<source_username> touser=<target_username> ignore=y

<wbr></wbr>

2.把导入到的用户的表空间默认为表需要导入的表空间

<wbr><span style="color:#993366">当不具unlimited tablespace权限时,用户的表空间范围被限制在配额内<br><wbr>当具有unlimited tablespace权限时,即使设置了表空间的配额,用户实际也能突破配额限制</wbr></span></wbr>

<wbr></wbr>

step1:收回要导入用户的无限制表空间权限

revoke<wbr>unlimited<wbr>tablespace<wbr></wbr></wbr></wbr>from<wbr>username;<wbr><wbr></wbr></wbr></wbr>

revoke unlimited tablespace from username;

<wbr></wbr>

step2:将希望导入的表空间设为目的用户的默认表空间,并添加配额

alter<wbr></wbr>user<wbr>&lt;username&gt;<wbr></wbr></wbr>default<wbr>tablespace<wbr>&lt;tablespace<wbr></wbr></wbr></wbr>name>quota<wbr>unlimited<wbr></wbr></wbr>on<wbr>&lt;username&gt;;<wbr><wbr><wbr></wbr></wbr></wbr></wbr>

alter user <username> default tablespace <tablespace name>quota unlimited on <username>;

<wbr></wbr>

step3:导入dmp到目标用户即可,此时导入的表的表空间会设置为用户的表空间即需要导入的表空间

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值