如何查看我的数据库是否有索引?

如果是特定的桌子呢?


当前回答

如果你想一次性查看所有数据库的所有索引:

use information_schema;
SELECT * FROM statistics;

其他回答

在我的例子中,这适用于在对应的表中获取索引字段的表名和列名。

SELECT TABLE_NAME , COLUMN_NAME, COMMENT 
FROM information_schema.statistics
WHERE table_schema = 'database_name';

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

select * from sys.schema_index_statistics;

要查看特定表的索引,请使用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子句将显示所有模式中的所有索引。

SHOW INDEX FROM mytable FROM mydb;

SHOW INDEX FROM mydb.mytable;

见文档。

使用SHOW INDEXES语句查询表的索引信息,如下所示:

 SHOW INDEXES FROM table_name;

如果你没有连接到任何数据库,或者你想在不同的数据库中获取表的索引信息,你可以指定数据库名:

SHOW INDEXES FROM table_name 
IN database_name;

下面的查询与上面的查询类似:

SHOW INDEXES FROM database_name.table_name;

注意,INDEX和KEYS是INDEXES的同义词,IN是FROM的同义词,因此,您可以在SHOW INDEXES列中使用这些同义词。例如:

SHOW INDEX IN table_name 
FROM database_name;

Or

 SHOW KEYS FROM tablename
 IN databasename;