首页 > 代码库 > 数据泵逻辑迁移后sequence的唯一冲突
数据泵逻辑迁移后sequence的唯一冲突
前言
总结一个老生常谈的话题,利用数据泵执行逻辑导入时,经常会碰到sequence发生唯一冲突的问题,本文总结解决方式
原因
impdp执行导入时,按顺序先导入sequence(假定此时currval是100)而后导入表,但如果在这之间有人向表中插入数据或其它方式导致sequence被调用,导致此时currval增加到1000。数据导入完成后,sequence是从100开始取值,而100-1000的sequence已经被占用,导致唯一冲突
解决方式:
1.在dest端 drop掉sequence,从source端获取sequence的元数据到dest重新创建
2.数据库至于RESTRICT SESSION模式下,执行导出
3.将SEQUENCE的CACHE设置为一个较大的值,确保导出序列和导出表数据之前的时间内,序列CACHE的值不会被用完,这就保证了导入后不会出现序列值的NEXTVAL小于表中已有数据的情况
本文出自 “oracle一体机” 博客,请务必保留此出处http://woquer.blog.51cto.com/9290811/1863454
数据泵逻辑迁移后sequence的唯一冲突
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。