小议IMP操作参数COMMIT=Y(三)

前一段时间在论坛上看到imp的COMMIT参数问题,于是打算简单总结一下。

这篇文章讨论COMMIT=Y对数据完整性的影响。

小议IMP操作参数COMMIT=Y(一):http://yangtingkun.itpub.net/post/468/254854

小议IMP操作参数COMMIT=Y(二):http://yangtingkun.itpub.net/post/468/255388


导入时设置COMMIT=Y不仅会带来性能方面的影响,更重要的时,设置了这个参数有可能导致数据的一致性出现问题,尤其是配合IGNORE=Y参数一起使用的时候。

如果设置了COMMIT=Y,那么导入过程会在一条数据或buffer中所有的数据插入后,进行提交。这意味着导入操作不再是一个事务。因此,当导入过程中途失败,Oracle回滚的只是最后一次插入的事务,而前面插入的数据都以及提交了。这可能意味着用户将很难恢复到导入开始的时刻,而且也很难继续导入未完的数据。

当然,两种情况可以避免出现这种问题。第一种情况就是导入的表本身不存在,或者是空的。这样可以简单的DROP TABLE或TRUNCATE TABLE清除所有已经导入的数据。

第二种情况是表本身有主键、唯一约束或唯一索引。这种情况虽然不是很容易恢复到导入之前的状态,但是利用主键等唯一约束,再次执行导入时,所有以及插入的数据在重新导入时都会报错,而上次未导入的数据则可以顺利导入。这种情况的问题是,由于导入操作会导致唯一性冲突错误,IMP时会报大量的错误,导入性能严重下降。导入的效率可能下降将近10倍。

所以在对以及存在数据的表执行IMP的时候,应该尽量的避免设置COMMIT=Y参数。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/4227/viewspace-69152/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/4227/viewspace-69152/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值