导入时候索引创建失败解决方法

本文记录了一次Oracle数据库中索引创建失败的问题及解决过程。错误代码ORA-39083与ORA-29958指出在执行ODCIINDEXCREATE例程时发生致命错误,ORA-00972表明标识符过长。通过获取并修改索引的DDL语句,最终成功重建索引。文章还提到了导出参数exclude=statistics的作用与后续的统计信息收集。

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

报错信息

Processing object type TABLE_EXPORT/TABLE/TABLE
Processing object type TABLE_EXPORT/TABLE/TABLE_DATA
. . imported "T24"."STF_TEM_CAR000"                      8.458 GB 11616355 rows
Processing object type TABLE_EXPORT/TABLE/INDEX/INDEX
Processing object type TABLE_EXPORT/TABLE/CONSTRAINT/CONSTRAINT
Processing object type TABLE_EXPORT/TABLE/INDEX/DOMAIN_INDEX/INDEX
ORA-39083: Object type INDEX:"T24"."IX_STF_TEM_CAR000" failed to create with error:
ORA-29958: fatal error occurred in the execution of ODCIINDEXCREATE routine
ORA-00972: identifier is too long

Failing sql is:
CREATE INDEX "T24"."IX_STF_TEM_CAR000" ON "T24"."STF_TEM_CAR000" ("XMLRECORD")  INDEXTYPE IS "XDB"."XMLINDEX"  PARAMETERS ('PATH TABLE (TABLESPACE T24INDEXXML) PATHS (INCLUDE (/row/c43))')PARALLEL 1 

 

解决方法:

可以去原库使用命令查找:select DBMS_METADATA.GET_DDL('INDEX','IX_STF_TEM_CAR000','T24')FROM DUAL; 查找重建索引的SQL语句
查询出来的结果信息可能不完整需要
set long 20000;
set pagesie 20000;
然后复制黏贴到目标库,重建
(example:
CREATE INDEX "T24"."IX_STF_TEM_CAR000" ON "T24"."STF_TEM_CAR000" ("XMLRECORD")  
INDEXTYPE IS "XDB"."XMLINDEX"  PARAMETERS ('PATH TABLE (TABLESPACE T24INDEXXML) PATHS (INCLUDE (/row/c43))');)
因为导出的时候加入参数“exclude=statistics”排除统计信息不导出,是因为可以增加导出的速度,最后导入后需要统计信息,统计一下表信息
exec dbms_stats.gather_table_stats('T24','STF_TEM_CAR000')

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值