ADMIN CLEANUP INDEX
ADMIN CLEANUP INDEX
语句用于删除表中冗余的索引,当表存在不一致的数据和索引时。注意,该语法目前尚不支持 foreign key constraints。
概述
- AdminCleanupStmt
- TableNameList
AdminCleanupStmt ::=
'ADMIN' 'CLEANUP' ( 'INDEX' TableName IndexName | 'TABLE' 'LOCK' TableNameList )
TableNameList ::=
TableName ( ',' 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 语法的扩展。