文档首页 > > 开发指南> 优化查询性能> 改进查询> 例行重建索引

例行重建索引

分享
更新时间: 2019/06/24 GMT+08:00

背景信息

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

数据库支持的索引类型包含B-tree索引、GIN索引和PSORT索引。

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

重建索引

重建索引有以下两种方式:

  • 先删除索引(DROP INDEX),再创建索引(CREATE INDEX)。

    在删除索引过程中,会在父表上增加一个短暂的排他锁,阻止相关读写操作。在创建索引过程中,会锁住写操作但是不会锁住读操作,此时读操作只能使用顺序扫描。

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

操作步骤

假定在导入表“areaS”上的“area_id”字段上存在普通索引“areaS_idx”。重建索引有以下两种方式:
  • 先删除索引(DROP INDEX),再创建索引(CREATE INDEX)
    1. 删除索引。
      DROP INDEX areaS_idx;
      DROP INDEX
    2. 创建索引。
      CREATE INDEX areaS_idx ON areaS (area_id);
      CREATE INDEX
  • 使用REINDEX重建索引。
    • 使用REINDEX TABLE语句重建索引。
      REINDEX TABLE areaS;
      REINDEX
    • 使用REINDEX INTERNAL TABLE重建desc表(包括)的索引。
      REINDEX INTERNAL TABLE areaS;
      REINDEX
分享:

    相关文档

    相关产品

文档是否有解决您的问题?

提交成功!

非常感谢您的反馈,我们会继续努力做到更好!

反馈提交失败,请稍后再试!

*必选

请至少选择或填写一项反馈信息

字符长度不能超过200

提交反馈 取消

如您有其它疑问,您也可以通过华为云社区问答频道来与我们联系探讨

跳转到云社区