Oracle 数据导入的一点心得

本文分享了在Oracle数据库中导入大容量数据时遇到的问题及解决办法,包括表空间分配、索引处理以及如何避免不必要的数据导入。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


Oracle数据导入 

imp user/passwd file=abc.dmp tables=abc indexes=n
Oracle数据导入时(dmp文件)
有一回导数据,数据量比较大,压缩的dmp文件有15G,需要将数据往公司的测试数据库上导。
本以为很简单,传好dmp文件,imp导入即可。结果貌似简单的过程,却耗费了我不少的时间。
导入前,建立表空间(dvbboss: 80G),建立用户并指定该表空间。然后导入,在导了半个小时左右后
发现报错,意思是指定的表空间已满,不能导入了。我郁闷了,80G的表空间还不够?于是查
了一下,令人惊讶的是根据用户指定的表空间占用率还是0,而已经满了的表空间只有两个:
INDX(索引表空间)和dvbcetus,都已经到了99%。将imp停止,并将该用户删除,发现一个
情况是,对应的这两个表空间又恢复到原来的状态了,几乎是没有使用。

按照原本的设想,我不导入索引的话,应该对INDX表空间没有影响的,但是为何还是导入了
这么多的数据呢。查了不少资料,发现还有个强制约束的索引。如果光指定indexes=n,则只
是将一般的索引排出掉不导入,对于这个也需要进行限制,即:constraints=n,这样限定后
产看INDX表空间发现没有增长。
约束往往和一个唯一索引/主键相关联,所以仅仅利用indexes=n 选项是不够的,必须添加CONSTRAINTS=n,才能真正避免导入时的检查。

另外一个表空间的增长,后来发现是这个原因所导致的:
如果数据库已经存在dmp文件中建表所需要的表空间,则默认会往该表空间中增加表及数据
如果没有不存在该表空间,则会按照建立用户:user的时候所指定的表空间里建表与数据。
 

总结的不是很好,有空再来理理。。。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值