写点什么

【YashanDB 知识库】如何解决删除分区后索引失效问题

作者:YashanDB
  • 2025-01-10
    广东
  • 本文字数:1484 字

    阅读完需:约 5 分钟

本文内容来自 YashanDB 官网,原文内容请见 https://www.yashandb.com/newsinfo/7863049.html?templateId=1718516


问题现象


删除分区后,插入数据报错 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 状态,插入数据时,数据可以插入成功。


<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 版本还不支持删除分区时,更新索引,只做了语法兼容。



发布于: 刚刚阅读数: 5
用户头像

YashanDB

关注

全自研国产新型大数据管理系统 2022-02-15 加入

还未添加个人简介

评论

发布
暂无评论
【YashanDB知识库】如何解决删除分区后索引失效问题_数据库_YashanDB_InfoQ写作社区