如何解决删除分区后索引失效问题
问题现象
删除分区后,插入数据报错YAS-02040 index partition is unusable,如下图:
问题的风险及影响
插入数据报错,影响正常业务
问题影响的版本
所有版本
解决方法及规避方式
重建索引即可:
ALTER INDEX orders_info_order_no_idx REBUILD;
问题发生原因
例子如下:
CREATE TABLE orders_info( order_no varchar(20) , order_desc VARCHAR2(100), area CHAR(2), branch CHAR(4), order_date DATE DEFAULT SYSDATE NOT NULL, salesperson CHAR(10), intime date, id NUMBER ) PARTITION BY RANGE (intime,id) ( PARTITION p1 VALUES LESS THAN (to_date('2021-01-01','yyyy-mm-dd'),1000), PARTITION p2 VALUES LESS THAN (to_date('2022-01-01','yyyy-mm-dd'),2000), PARTITION p3 VALUES LESS THAN (to_date('2023-01-01','yyyy-mm-dd'),3000), PARTITION p4 VALUES LESS THAN (maxvalue,maxvalue) ); -- create unique index orders_info_order_no_idx on orders_info(order_no); create index orders_info_area_idx on orders_info(area) local; INSERT INTO orders_info VALUES ('20010102020001','product 001','02','0201',SYSDATE-400,'0001',to_date('2021-01-01','yyyy-mm-dd'),800); INSERT INTO orders_info VALUES ('20010102020002','product 001','02','0201',SYSDATE-400,'0001',to_date('2021-01-01','yyyy-mm-dd'),1500); INSERT INTO orders_info VALUES ('20010102020003','product 001','02','0201',SYSDATE-400,'0001',to_date('2022-01-01','yyyy-mm-dd'),1200); INSERT INTO orders_info VALUES ('20010102020004','product 001','02','0201',SYSDATE-400,'0001',to_date('2022-01-01','yyyy-mm-dd'),2400); INSERT INTO orders_info VALUES ('20010102020005','product 001','02','0201',SYSDATE-400,'0001',to_date('2023-01-01','yyyy-mm-dd'),2500); INSERT INTO orders_info VALUES ('20010102020006','product 001','02','0201',SYSDATE-400,'0001',to_date('2023-01-01','yyyy-mm-dd'),3500); COMMIT; |
yashandb数据库删除分区时,索引表现如下:
1、分区索引,没有影响
2、非unique全局索引,转变为unusable状态,插入数据时,数据可以插入成功。
--当创建的orders_info_order_no_idx不是unique索引时,删除分区 create index orders_info_order_no_idx on orders_info(order_no); alter table orders_info drop partition p2 ; |
删除分区后,插入数据,插入成功,如下图:
3、主健索引、unique全局索引,转变为unusable状态,插入数据时,会报错index unusable。
--当创建的orders_info_order_no_idx是unique索引时,删除分区 create unique index orders_info_order_no_idx on orders_info(order_no); alter table orders_info drop partition p2 ; |
删除分区后,插入数据,插入失败,如下图:
4、如果想删除分区时,全局索引不失效。
oracle删除分区时,选择更新索引项,可以看到索引没有变为unusable,插入数据也成功,如下:
alter table orders_info drop partition p2 UPDATE GLOBAL INDEXES;
yashandb 23.2版本还不支持删除分区时,更新索引,只做了语法兼容。
友情链接:深圳计算科学研究院 深圳崖山科技有限公司
版权所有© 深圳崖山科技有限公司 粤ICP备2022018810号
公众号
加入技术交流群
YashanDB
崖山数据库系统YashanDB是深圳计算科学研究院自主设计研发的新型数据库管理系统,融入原创的有界计算、近似计算、并行可扩展和跨模融合计算理论,可满足金融、政企、能源等关键行业对高性能、高并发及高安全性的要求。
邮箱:info@yashandb.com
地址:广东省深圳市龙华区民宝路红山6979园区25座5-10层