-
Notifications
You must be signed in to change notification settings - Fork 688
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Yang Keao <[email protected]>
- Loading branch information
Showing
4 changed files
with
98 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
--- | ||
title: TIDB_INDEX_USAGE | ||
summary: Learn the `TIDB_INDEX_USAGE` information_schema table. | ||
--- | ||
|
||
# TIDB_INDEX_USAGE | ||
|
||
`TIDB_INDEX_USAGE` records the access statistics of all indexes on the current node. | ||
|
||
{{< copyable "sql" >}} | ||
|
||
```sql | ||
USE information_schema; | ||
DESC tidb_index_usage; | ||
``` | ||
|
||
```sql | ||
+--------------------------+-------------+------+------+---------+-------+ | ||
| Field | Type | Null | Key | Default | Extra | | ||
+--------------------------+-------------+------+------+---------+-------+ | ||
| TABLE_SCHEMA | varchar(64) | YES | | NULL | | | ||
| TABLE_NAME | varchar(64) | YES | | NULL | | | ||
| INDEX_NAME | varchar(64) | YES | | NULL | | | ||
| QUERY_TOTAL | bigint(21) | YES | | NULL | | | ||
| KV_REQ_TOTAL | bigint(21) | YES | | NULL | | | ||
| ROWS_ACCESS_TOTAL | bigint(21) | YES | | NULL | | | ||
| PERCENTAGE_ACCESS_0 | bigint(21) | YES | | NULL | | | ||
| PERCENTAGE_ACCESS_0_1 | bigint(21) | YES | | NULL | | | ||
| PERCENTAGE_ACCESS_1_10 | bigint(21) | YES | | NULL | | | ||
| PERCENTAGE_ACCESS_10_20 | bigint(21) | YES | | NULL | | | ||
| PERCENTAGE_ACCESS_20_50 | bigint(21) | YES | | NULL | | | ||
| PERCENTAGE_ACCESS_50_100 | bigint(21) | YES | | NULL | | | ||
| PERCENTAGE_ACCESS_100 | bigint(21) | YES | | NULL | | | ||
| LAST_ACCESS_TIME | datetime | YES | | NULL | | | ||
+--------------------------+-------------+------+------+---------+-------+ | ||
14 rows in set (0.00 sec) | ||
``` | ||
|
||
The columns in the `TIDB_INDEX_USAGE` table are as follows: | ||
|
||
* `TABLE_SCHEMA`: The name of the database to which the table containing the index belongs. | ||
* `TABLE_NAME`: The name of the table containing the index. | ||
* `INDEX_NAME`: The name of the index. | ||
* `QUERY_TOTAL`: The total number of statements accessing the index. | ||
* `KV_REQ_TOTAL`: The total number of KV requests generated when accessing the index. | ||
* `ROWS_ACCESS_TOTAL`: The total number of rows scanned when accessing the index. | ||
* `PERCENTAGE_ACCESS_0`: The number of times the access ratio of rows to the total number of rows in the table is 0. | ||
* `PERCENTAGE_ACCESS_0_1`: The number of times the access ratio of rows to the total number of rows in the table is between 0% and 1%. | ||
* `PERCENTAGE_ACCESS_1_10`: The number of times the access ratio of rows to the total number of rows in the table is between 1% and 10%. | ||
* `PERCENTAGE_ACCESS_10_20`: The number of times the access ratio of rows to the total number of rows in the table is between 10% and 20%. | ||
* `PERCENTAGE_ACCESS_20_50`: The number of times the access ratio of rows to the total number of rows in the table is between 20% and 50%. | ||
* `PERCENTAGE_ACCESS_50_100`: The number of times the access ratio of rows to the total number of rows in the table is between 50% and 100%. | ||
* `PERCENTAGE_ACCESS_100`: The number of times the access ratio of rows to the total number of rows in the table is 100%. | ||
* `LAST_ACCESS_TIME`: The time when the index was last accessed. | ||
|
||
# Limitations | ||
|
||
- The data in the `TIDB_INDEX_USAGE` table may be delayed by up to 5 minutes. | ||
- After TiDB restarts, the data in the `TIDB_INDEX_USAGE` table is cleared. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
--- | ||
title: sys Schema | ||
summary: Learn about the system tables in the `sys` schema. | ||
--- | ||
|
||
# `sys` Schema | ||
|
||
> **Note:** | ||
> | ||
> The cluster upgrades from lower version than v8.0.0 will not have `sys` Schema and the views in it. `sys` and the view inside can be created by the following SQLs: | ||
> | ||
> {{< copyable "sql" >}} | ||
> | ||
> ```sql | ||
> CREATE DATABASE IF NOT EXISTS sys; | ||
> CREATE OR REPLACE VIEW sys.schema_unused_indexes AS | ||
> SELECT | ||
> table_schema as object_schema, | ||
> table_name as object_name, | ||
> index_name | ||
> FROM information_schema.cluster_tidb_index_usage | ||
> WHERE | ||
> table_schema not in ('sys', 'mysql', 'INFORMATION_SCHEMA', 'PERFORMANCE_SCHEMA') and | ||
> index_name != 'PRIMARY' | ||
> GROUP BY table_schema, table_name, index_name | ||
> HAVING | ||
> sum(last_access_time) is null; | ||
> ``` | ||
Tables and views in the `sys` schema are used to help users understand the data in TiDB's system tables, `INFORMATION_SCHEMA` database, and `PERFORMANCE_SCHEMA` database. | ||
- `schema_unused_index` is used to record indexes that have not been used since the last restart of TiDB. | ||
- `OBJECT_SCHEMA`: The name of the database to which the table containing the index belongs. | ||
- `OBJECT_NAME`: The name of the table containing the index. | ||
- `INDEX_NAME`: The name of the index. |