【发布时间】:2011-07-09 23:00:37
【问题描述】:
如何查看我的数据库是否有任何索引?
具体的表呢?
【问题讨论】:
-
只使用:sp_helpindex '表名'
-
"只需使用:sp_helpindex 'table name'" 接缝为 SQL Server (MSSQL) @user3772443 而不是 MySQL
标签: mysql indexing database-schema
如何查看我的数据库是否有任何索引?
具体的表呢?
【问题讨论】:
标签: mysql indexing database-schema
要查看特定表的索引,请使用 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 子句将显示所有架构中的所有索引。
【讨论】:
DISTINCT 关键字会屏蔽一些索引 - 我有一个表,其中索引具有相同名称但用于两个不同的列,因此此处的信息架构示例将仅显示一个索引.
如果您想同时查看所有数据库中的所有索引:
use information_schema;
SELECT * FROM statistics;
【讨论】:
SELECT * FROM information_schema.statistics;
SHOW INDEX FROM mytable FROM mydb;
SHOW INDEX FROM mydb.mytable;
【讨论】:
您可以使用此查询来获取索引的编号以及指定数据库中每个表的索引名称。
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;
【讨论】:
按顺序获取一列中每个索引的所有索引列。
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/
【讨论】:
我提出这个查询:
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';
您找到了所有索引仅索引。
注意。
【讨论】:
为什么不show create table myTable?
有人告诉我这个,但我没有看到有人提到这里,有什么不好的吗?
如果您只想看一下索引和列信息,那就太好了。
【讨论】:
要查看您创建的索引,请使用
SHOW INDEX from your_table_name;
查看表上的所有索引(由 DB 和您创建)
SHOW EXTENDED INDEX from your_table_name;
【讨论】:
检查数据库上所有禁用的索引
SELECT INDEX_SCHEMA, COLUMN_NAME, COMMENT
FROM information_schema.statistics
WHERE table_schema = 'mydb'
AND COMMENT = 'disabled'
【讨论】:
您可以在 MySQL 工作台中检查您的索引。在性能报告选项卡下,您可以看到系统上所有使用的索引和未使用的索引。或者您可以触发查询。
select * from sys.schema_index_statistics;
【讨论】:
在我的情况下,这适用于在索引字段的相应表中获取表名和列名。
SELECT TABLE_NAME , COLUMN_NAME, COMMENT
FROM information_schema.statistics
WHERE table_schema = 'database_name';
【讨论】:
查询表的索引信息,使用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;
或者
SHOW KEYS FROM tablename
IN databasename;
【讨论】:
如果我们知道下面的索引名称,我们可以直接看到表上的索引:
select * from all_indexes where index_name= 'your index'
【讨论】: