【YashanDB 知识库】如何解决删除分区后索引失效问题
本文内容来自 YashanDB 官网,原文内容请见 https://www.yashandb.com/newsinfo/7863049.html?templateId=1718516
问题现象
删除分区后,插入数据报错 YAS-02040 index partition is unusable,如下图:
问题的风险及影响
插入数据报错,影响正常业务
问题影响的版本
所有版本
解决方法及规避方式
重建索引即可:
ALTER INDEX orders_info_order_no_idx REBUILD;
问题发生原因
例子如下:
yashandb 数据库删除分区时,索引表现如下:
1、分区索引,没有影响
2、非 unique 全局索引,转变为 unusable 状态,插入数据时,数据可以插入成功。
<table cellspacing="0"><tbody><tr><td><p><span>--当创建的 orders_info_order_no_idx 不是 unique 索引时,删除分区</span></p><p><span>create index orders_info_order_no_idx on orders_info(order_no);</span></p><p><span>alter table orders_info drop partition p2 ;</span></p></td></tr></tbody></table>
删除分区后,插入数据,插入成功,如下图:
3、主健索引、unique 全局索引,转变为 unusable 状态,插入数据时,会报错 index unusable。
<table cellspacing="0"><tbody><tr><td><p><span>--当创建的 orders_info_order_no_idx 是 unique 索引时,删除分区</span></p><p><span>create unique index orders_info_order_no_idx on orders_info(order_no);</span></p><p><span>alter table orders_info drop partition p2 ;</span></p></td></tr></tbody></table>
删除分区后,插入数据,插入失败,如下图:
4、如果想删除分区时,全局索引不失效。
oracle 删除分区时,选择更新索引项,可以看到索引没有变为 unusable,插入数据也成功,如下:
alter table orders_info drop partition p2 UPDATE GLOBAL INDEXES;
yashandb 23.2 版本还不支持删除分区时,更新索引,只做了语法兼容。
版权声明: 本文为 InfoQ 作者【YashanDB】的原创文章。
原文链接:【http://xie.infoq.cn/article/65d63bf68be5faf8903a6f51e】。文章转载请联系作者。
评论