数据泵逻辑迁移后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小于表中已有数据的情况




本文标题:数据泵逻辑迁移后sequence的唯一冲突
本文路径:http://myzitong.com/article/jidgpp.html