如何查看我的数据库是否有索引?
如果是特定的桌子呢?
如何查看我的数据库是否有索引?
如果是特定的桌子呢?
当前回答
您可以使用此查询来获取指定数据库中每个表的索引名和索引号。
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;
其他回答
如果你想一次性查看所有数据库的所有索引:
use information_schema;
SELECT * FROM statistics;
为什么不显示创建表myTable ?
有人告诉过我,但我没看到有人提到,有什么不好的吗?
如果您只想看一下索引和列信息,那就很简单了。
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;
如果我们知道下面的索引名,我们可以直接看到表上的索引:
Select * from all_indexes where index_name= 'your index'