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

时间:2011-03-06 20:55:53

标签: mysql indexing database-schema

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

特定桌子怎么样?

13 个答案:

答案 0 :(得分:643)

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

答案 1 :(得分:42)

如果要同时查看所有数据库中的所有索引:

use information_schema;
SELECT * FROM statistics;

答案 2 :(得分:36)

SHOW INDEX FROM mytable FROM mydb;

SHOW INDEX FROM mydb.mytable;

请参阅documentation

答案 3 :(得分:5)

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

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;

答案 4 :(得分:3)

我建议这个查询:

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';

您找到了所有索引索引。

方面。

答案 5 :(得分:2)

为什么不show create table myTable

有人告诉我这个,但我没看到有人提到这里,有什么不好的吗?

如果您只想看一眼索引和列信息,这很方便。

答案 6 :(得分:1)

检查db

上的所有已禁用索引
SELECT INDEX_SCHEMA, COLUMN_NAME, COMMENT 
FROM information_schema.statistics
WHERE table_schema = 'mydb'
AND COMMENT = 'disabled'

答案 7 :(得分:1)

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

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

答案 8 :(得分:0)

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

select * from sys.schema_index_statistics;

答案 9 :(得分:0)

要按顺序在一个列中获取每个索引的所有索引列。

SELECT table_name AS `Table`,
       index_name AS `Index`,
       GROUP_CONCAT(column_name ORDER BY seq_in_index) AS `Columns`
FROM information_schema.statistics
WHERE table_schema = 'sakila'
GROUP BY 1,2;

参考:http://blog.9minutesnooze.com/mysql-information-schema-indexes/

答案 10 :(得分:0)

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

body { 
    padding-top: 65px; 
}

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

 SHOW INDEXES FROM table_name;

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

SHOW INDEXES FROM table_name 
IN database_name;

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

SHOW INDEXES FROM database_name.table_name;

SHOW INDEX IN table_name 
FROM database_name;

答案 11 :(得分:0)

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

select * from all_indexes where index_name='你的索引'

答案 12 :(得分:0)

查看您创建的索引使用

SHOW INDEX from your_table_name;

查看表上的所有索引(由 DB 和您创建)

SHOW EXTENDED INDEX from your_table_name;