【问题标题】:How to see indexes for a database or table in MySQL?如何在 MySQL 中查看数据库或表的索引?
【发布时间】:2011-07-09 23:00:37
【问题描述】:

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

具体的表呢?

【问题讨论】:

  • 只使用:sp_helpindex '表名'
  • "只需使用:sp_helpindex 'table name'" 接缝为 SQL Server (MSSQL) @user3772443 而不是 MySQL

标签: mysql indexing database-schema


【解决方案1】:

要查看特定表的索引,请使用 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 关键字会屏蔽一些索引 - 我有一个表,其中索引具有相同名称但用于两个不同的列,因此此处的信息架构示例将仅显示一个索引.
  • @Mark Byers 有没有办法查看索引表本身? SQL如何在内部生成索引文件?它如何存储索引表到主表的记录指针?
  • 所以我的表出现在 INFORMATION_SCHEMA.STATISTICS 但它只有一个条目,即 index_name。没有其他条目来指示列名。所有其他表都有多个条目,显示如下: PRIMARY c1, c2 其中 c1, c2 构成复合主键。知道为什么吗?
【解决方案2】:

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

use information_schema;
SELECT * FROM statistics;

【讨论】:

  • 单线:SELECT * FROM information_schema.statistics;
【解决方案3】:
SHOW INDEX FROM mytable FROM mydb;

SHOW INDEX FROM mydb.mytable;

documentation

【讨论】:

    【解决方案4】:

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

    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;
    

    【讨论】:

      【解决方案5】:

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

      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/

      【讨论】:

        【解决方案6】:

        我提出这个查询:

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

        您找到了所有索引索引。

        注意。

        【讨论】:

          【解决方案7】:

          为什么不show create table myTable

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

          如果您只想看一下索引和列信息,那就太好了。

          【讨论】:

            【解决方案8】:

            要查看您创建的索引,请使用

            SHOW INDEX from your_table_name;
            

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

            SHOW EXTENDED INDEX from your_table_name;
            

            【讨论】:

              【解决方案9】:

              检查数据库上所有禁用的索引

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

              【讨论】:

                【解决方案10】:

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

                select * from sys.schema_index_statistics;
                

                【讨论】:

                • Paul 您使用的是哪个工具?此代码适用于 mysql workbeanch。
                • 我在 MySQL shell 中使用过
                • 你能用Mysql Workbench试试这个吗? select * from sys.schema_index_statistics;
                【解决方案11】:

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

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

                【讨论】:

                  【解决方案12】:

                  查询表的索引信息,使用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;
                  

                  【讨论】:

                    【解决方案13】:

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

                    select * from all_indexes where index_name= 'your index'

                    【讨论】:

                      猜你喜欢
                      • 2014-11-26
                      • 2016-03-26
                      • 1970-01-01
                      • 2019-06-04
                      • 2018-10-02
                      • 2012-04-08
                      • 1970-01-01
                      • 2012-11-29
                      • 1970-01-01
                      相关资源
                      最近更新 更多