【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;

问题发生原因

例子如下:

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

posted @   YashanDB  阅读(4)  评论(0编辑  收藏  举报
编辑推荐:
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
阅读排行:
· [翻译] 为什么 Tracebit 用 C# 开发
· 腾讯ima接入deepseek-r1,借用别人脑子用用成真了~
· Deepseek官网太卡,教你白嫖阿里云的Deepseek-R1满血版
· DeepSeek崛起:程序员“饭碗”被抢,还是职业进化新起点?
· RFID实践——.NET IoT程序读取高频RFID卡/标签
点击右上角即可分享
微信分享提示