📣

TiDB Cloud Serverless 现已更名为
Starter
!此页面由 AI 自动翻译,英文原文请见
此处。

ADMIN CLEANUP INDEX

ADMIN CLEANUP INDEX 语句用于删除表中冗余的索引,当表存在不一致的数据和索引时。注意,该语法目前尚不支持 foreign key constraints

概述

AdminCleanupStmt
ADMINCLEANUPINDEXTableNameIndexNameTABLELOCKTableNameList
TableNameList
TableName,

示例

假设某个数据库中的 tbl 表由于某些原因(例如,在灾难恢复场景中集群中部分行数据丢失)导致数据和索引不一致:

SELECT * FROM tbl; ERROR 1105 (HY000): inconsistent index idx handle count 3 isn't equal to value count 2 ADMIN CHECK INDEX tbl idx ; ERROR 1105 (HY000): handle &kv.CommonHandle{encoded:[]uint8{0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0xf8}, colEndOffsets:[]uint16{0xa}}, index:types.Datum{k:0x5, decimal:0x0, length:0x0, i:0, collation:"utf8mb4_bin", b:[]uint8{0x0}, x:interface {}(nil)} != record:<nil>

SELECT 查询的错误信息可以看出,tbl 表中存在两行数据和三行索引数据,说明行数据和索引数据不一致。同时,至少有一个索引处于悬挂状态。在这种情况下,可以使用 ADMIN CLEANUP INDEX 语句删除悬挂的索引:

ADMIN CLEANUP INDEX tbl idx;

执行结果如下:

ADMIN CLEANUP INDEX tbl idx; +---------------+ | REMOVED_COUNT | +---------------+ | 1 | +---------------+

你可以再次执行 ADMIN CHECK INDEX 语句,检查数据和索引的一致性,确认数据是否已恢复到正常状态:

ADMIN CHECK INDEX tbl idx; Query OK, 0 rows affected (0.01 sec)

MySQL 兼容性

该语句是 TiDB 对 MySQL 语法的扩展。

相关链接

文档内容是否有帮助?