数据泵逻辑迁移后sequence的唯一冲突

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据泵逻辑迁移后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的唯一冲突的主要内容,如果未能解决你的问题,请参考以下文章

OracleDBA职责—备份与恢复技术—逻辑备份1

数据泵导出导入

LOB对象在数据泵导出导入后查询对象数量发现丢失

Oracle 数据泵迁移用户创建 SQL语句

Oracle 数据泵迁移用户创建 SQL语句

使用Oracle数据泵迁移数据库