如何在MySQL中查看数据库或表的索引?


Answers:


793

要查看特定表的索引,请使用SHOW INDEX:

SHOW INDEX FROM yourtable;

要查看特定模式中所有表的索引,可以使用INFORMATION_SCHEMA中的STATISTICS表:

SELECT DISTINCT
    TABLE_NAME,
    INDEX_NAME
FROM INFORMATION_SCHEMA.STATISTICS
WHERE TABLE_SCHEMA = 'your_schema';

删除where子句将为您显示所有架构中的所有索引。


10
请注意,该DISTINCT关键字将屏蔽某些索引-我有一个表,其中的索引具有相同的名称,但在两个不同的列上使用,因此此处的信息架构示例将仅显示一个索引。
2014年

from mydb如LiorK的答案所示,我必须添加。
Nate 2014年

@Mark Byers有没有办法查看索引表本身?SQL如何在内部生成索引文件?它如何存储从索引表到主表的记录的指针?
yajant b

因此,我的表显示在INFORMATION_SCHEMA.STATISTICS中,但它只有一个条目index_name。没有其他条目可指示列名称。所有其他表都有多个条目,这些条目显示如下所示:PRIMARY c1,c2其中c1,c2组成复合主键。知道为什么吗?
Stevers

56

如果要一次查看所有数据库中的所有索引:

use information_schema;
SELECT * FROM statistics;

4
作为SELECT * FROM information_schema.statistics;
单线客车

44
SHOW INDEX FROM mytable FROM mydb;

SHOW INDEX FROM mydb.mytable;

请参阅文档


7

您可以使用此查询获取索引号以及指定数据库中每个表的索引名称。

SELECT TABLE_NAME,
       COUNT(1) index_count,
       GROUP_CONCAT(DISTINCT(index_name) SEPARATOR ',\n ') indexes
FROM INFORMATION_SCHEMA.STATISTICS
WHERE TABLE_SCHEMA = 'mydb'
      AND INDEX_NAME != 'primary'
GROUP BY TABLE_NAME
ORDER BY COUNT(1) DESC;

5

我提出这个查询:

SELECT DISTINCT s.*
FROM INFORMATION_SCHEMA.STATISTICS s
LEFT OUTER JOIN INFORMATION_SCHEMA.TABLE_CONSTRAINTS t 
    ON t.TABLE_SCHEMA = s.TABLE_SCHEMA 
       AND t.TABLE_NAME = s.TABLE_NAME
       AND s.INDEX_NAME = t.CONSTRAINT_NAME 
WHERE 0 = 0
      AND t.CONSTRAINT_NAME IS NULL
      AND s.TABLE_SCHEMA = 'YOUR_SCHEMA_SAMPLE';

您找到了所有索引索引。

看待。



2

检查数据库上所有禁用的索引

SELECT INDEX_SCHEMA, COLUMN_NAME, COMMENT 
FROM information_schema.statistics
WHERE table_schema = 'mydb'
AND COMMENT = 'disabled'

2

您可以在MySQL工作台中检查索引。在性能报告选项卡下,您可以查看系统上所有使用的索引和未使用的索引。或者您可以触发查询。

select * from sys.schema_index_statistics;

Paul,您正在使用哪个工具?此代码适用于mysql workbeanch。
格林尼治·吉里

我用它在MySQL外壳
保罗Basenko

您可以使用Mysql Workbench尝试这种方法吗?从sys.schema_index_statistics中选择*;
Ganesh Giri

2

在我的情况下,这适用于在索引字段的相应表中获取表名和列名。

SELECT TABLE_NAME , COLUMN_NAME, COMMENT 
FROM information_schema.statistics
WHERE table_schema = 'database_name';
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.