【GaussDB】重建索引

本文探讨了数据库索引膨胀问题,介绍了B-tree索引的作用,以及如何通过DROPINDEX和CREATEINDEX或使用REINDEX语句进行重建索引,包括REINDEXTABLE和REINDEXINTERNALTABLE的不同操作方式。详细阐述了重建索引以提高查询效率的方法和步骤。
摘要由CSDN通过智能技术生成

1.背景信息


数据库经过多次删除操作后,索引页面上的索引键将被删除,造成索引膨胀。例行重建索引,可有效地提高查询效率。

数据库支持的索引类型为B-tree索引,例行重建索引可有效地提高查询效率。
•如果数据发生大量删除后,索引页面上的索引键将被删除,导致索引页面数量的减少,造成索引膨胀。
重建索引可回收浪费的空间。
•新建的索引中逻辑结构相邻的页面,通常在物理结构中也是相邻的,所以一个新建的索引比更新了
多次的索引访问速度要快。

2.重建索引

重建索引有以下两种方式:
•先运行DROP INDEX语句删除索引,再运行CREATE INDEX语句创建索引。
在删除索引过程中,会在父表上增加一个临时排他锁,阻止相关读写操作。在创建索引过程中,
会锁住写操作但是不会锁住读操作,此时读操作只能使用顺序扫描。

•使用REINDEX语句重建索引。
	◾使用REINDEX TABLE语句重建索引,会在重建过程中增加排他锁,阻止相关读写操作。
	◾使用REINDEX INTERNAL TABLE语句重建desc表(包括列存表的cudesc表)的索引,会在重建过程中增加排他锁,
阻止相关读写操作。

3.操作步骤

1).删除索引。
gaussdb=# DROP INDEX areaS_idx;
2).创建索引。
gaussdb=# CREATE INDEX areaS_idx ON areaS (area_id);
3)使用REINDEX重建索引
	◾使用REINDEX TABLE语句重建索引。
	gaussdb=# REINDEX TABLE areaS;
	◾使用REINDEX INTERNAL TABLE重建desc表(包括列存表的cudesc表)的索引。
	gaussdb=# REINDEX INTERNAL TABLE areaS;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值