本文内容来自YashanDB官网,原文内容请见 https://www.yashandb.com/newsinfo/7863049.html?templateId=171...
问题现象
删除分区后,插入数据报错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状态,插入数据时,数据可以插入成功。
<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> |
<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> |
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。