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

如果是特定的桌子呢?


当前回答

查询数据库中所有已禁用的索引

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

其他回答

如果我们知道下面的索引名,我们可以直接看到表上的索引:

Select * from all_indexes where index_name= 'your index'

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

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

要查看特定表的索引,请使用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 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;

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

select * from sys.schema_index_statistics;