TIDB_インデックス

TIDB_INDEXESテーブルはすべてのテーブルの INDEX 情報を提供します。

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_IDINDEX_IDを取得し、次の SQL ステートメントを使用して特定のインデックス情報を取得できます。

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

TIDB_INDEXESテーブル内のフィールドは次のように説明されます。

  • TABLE_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 : クラスター化インデックスかどうか。

このページは役に立ちましたか?