openGauss学习笔记-141 openGauss 数据库运维-例行维护-例行重建索引

文章目录

    • [openGauss学习笔记-141 openGauss 数据库运维-例行维护-例行重建索引](#openGauss学习笔记-141 openGauss 数据库运维-例行维护-例行重建索引)
      • [141.1 背景信息](#141.1 背景信息)
      • [141.2 重建索引](#141.2 重建索引)
      • [141.3 操作步骤](#141.3 操作步骤)

openGauss学习笔记-141 openGauss 数据库运维-例行维护-例行重建索引

141.1 背景信息

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

数据库支持的索引类型为B-tree索引,例行重建索引可有效的提高查询效率。

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

141.2 重建索引

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

  • 先运行DROP INDEX语句删除索引,再运行CREATE INDEX语句创建索引。

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

  • 使用REINDEX语句重建索引。

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

141.3 操作步骤

假定在导入表"areaS"上的"area_id"字段上存在普通索引"areaS_idx"。重建索引有以下两种方式:

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

    1. 删除索引。

      makefile 复制代码
      openGauss=# DROP INDEX areaS_idx;

      当结果显示如下信息,则表示删除成功。

      sql 复制代码
      DROP INDEX
    2. 创建索引。

      makefile 复制代码
      openGauss=# CREATE INDEX areaS_idx ON areaS (area_id);

      当结果显示如下信息,则表示创建成功。

      sql 复制代码
      CREATE INDEX
  • 使用REINDEX重建索引。

    • 使用REINDEX TABLE语句重建索引。

      makefile 复制代码
      openGauss=# REINDEX TABLE areaS;

      当结果显示如下信息,则表示重建成功。

      undefined 复制代码
      REINDEX
    • 使用REINDEX INTERNAL TABLE重建desc表(包括列存表的cudesc表)的索引。

      makefile 复制代码
      openGauss=# REINDEX INTERNAL TABLE areaS;

      当结果显示如下信息,则表示重建成功。

      undefined 复制代码
      REINDEX

说明: 在重建索引前,用户可以通过临时增大maintenance_work_mem和psort_work_mem的取值来加快索引的重建。
👍 点赞,你的认可是我创作的动力!

⭐️ 收藏,你的青睐是我努力的方向!

✏️ 评论,你的意见是我进步的财富!

相关推荐
IvorySQL8 小时前
PostgreSQL 技术日报 (3月9日)|EXPLAIN ANALYZE 计时优化与复制语法讨论
数据库·postgresql·开源
stark张宇12 小时前
MySQL 核心内幕:从索引原理、字段选型到日志机制与外键约束,一篇打通数据库任督二脉
数据库·mysql·架构
倔强的石头_12 小时前
融合数据库架构实践:关系型、JSON与全文检索的“一库多能”深度解析
数据库
星辰员14 小时前
KingbaseES数据库:ksql 命令行用户与权限全攻略,从创建到删除
数据库
华仔啊1 天前
千万别给数据库字段加默认值 null!真的会出问题
java·数据库·后端
随风飘的云2 天前
MySQL的慢查询优化解决思路
数据库
IvorySQL2 天前
PostgreSQL 技术日报 (3月7日)|生态更新与内核性能讨论
数据库·postgresql·开源
赵渝强老师2 天前
【赵渝强老师】金仓数据库的数据文件
数据库·国产数据库·kingbase·金仓数据库
随逸1773 天前
《Milvus向量数据库从入门到实战,手把手搭建语义检索系统》
数据库
神秘的猪头3 天前
🚀 React 开发者进阶:RAG 核心——手把手带你玩转 Milvus 向量数据库
数据库·后端·llm