📣

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

TIDB_INDEXES

TIDB_INDEXES 表提供所有表的索引信息。

USE information_schema; DESC tidb_indexes;
+---------------+---------------+------+------+---------+-------+ | Field | Type | Null | Key | Default | Extra | +---------------+---------------+------+------+---------+-------+ | TABLE_SCHEMA | varchar(64) | YES | | NULL | | | TABLE_NAME | varchar(64) | YES | | NULL | | | NON_UNIQUE | bigint(21) | YES | | NULL | | | KEY_NAME | varchar(64) | YES | | NULL | | | SEQ_IN_INDEX | bigint(21) | YES | | NULL | | | COLUMN_NAME | varchar(64) | YES | | NULL | | | SUB_PART | bigint(21) | YES | | NULL | | | INDEX_COMMENT | varchar(2048) | YES | | NULL | | | Expression | varchar(64) | YES | | NULL | | | INDEX_ID | bigint(21) | YES | | NULL | | | IS_VISIBLE | varchar(64) | YES | | NULL | | | CLUSTERED | varchar(64) | YES | | NULL | | +---------------+---------------+------+------+---------+-------+ 12 rows in set (0.00 sec)

INDEX_ID 是 TiDB 为每个索引分配的唯一 ID。它可以用来与从其他表或 API 获取的 INDEX_ID 进行连接操作。

例如,你可以在 SLOW_QUERY table 中获取涉及某些慢查询的 TABLE_IDINDEX_ID,然后使用以下 SQL 语句获取具体的索引信息:

SELECT tidb_indexes.* FROM tidb_indexes, tables WHERE tidb_indexes.table_schema = tables.table_schema AND tidb_indexes.table_name = tables.table_name AND tables.tidb_table_id = ? AND index_id = ?

TIDB_INDEXES 表中的字段说明如下:

  • TABLE_SCHEMA: 索引所属的 schema 名称。
  • TABLE_NAME: 索引所属的表名。
  • NON_UNIQUE: 如果索引是唯一的,值为 0;否则,值为 1
  • KEY_NAME: 索引名称。如果是主键,名称为 PRIMARY
  • SEQ_IN_INDEX: 索引中列的顺序编号,从 1 开始。
  • COLUMN_NAME: 索引所在列的名称。
  • SUB_PART: 索引的前缀长度。如果列部分索引,SUB_PART 表示索引字符的数量;否则,值为 NULL
  • INDEX_COMMENT: 索引的备注信息,在创建索引时添加。
  • INDEX_ID: 索引 ID。
  • IS_VISIBLE: 索引是否可见。
  • CLUSTERED: 是否为 clustered index

文档内容是否有帮助?