当前位置 主页 > 网站技术 > 代码类 >

    mysql索引使用率监控技巧(值得收藏!)

    栏目:代码类 时间:2019-09-12 18:12

    概述

    在关系数据库中,索引是一种单独的、物理的对数据库表中一列或多列的值进行排序的一种存储结构,它是某个表中一列或若干列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单。

    mysql中支持hash和btree索引。innodb和myisam只支持btree索引,而memory和heap存储引擎可以支持hash和btree索引

    1、查看当前索引使用情况

    我们可以通过下面语句查询当前索引使用情况:


    Handler_read_first 代表读取索引头的次数,如果这个值很高,说明全索引扫描很多。 Handler_read_key代表一个索引被使用的次数,如果我们新增加一个索引,可以查看Handler_read_key是否有增加,如果有增加,说明sql用到索引。 Handler_read_next 代表读取索引的下列,一般发生range scan。 Handler_read_prev 代表读取索引的上列,一般发生在ORDER BY … DESC。 Handler_read_rnd 代表在固定位置读取行,如果这个值很高,说明对大量结果集进行了排序、进行了全表扫描、关联查询没有用到合适的KEY。 Handler_read_rnd_next 代表进行了很多表扫描,查询性能低下。

    其实比较多应用场景是当索引正在工作,Handler_read_key的值将很高,这个值代表了一个行将索引值读的次数,很低的值表明增加索引得到的性能改善不高,因为索引并不经常使用。

    Handler_read_rnd_next 的值高则意味着查询运行低效,并且应该建立索引补救。这个值的含义是在数据文件中读下一行的请求数。如果正进行大量的表 扫描,Handler_read_rnd_next的值较高,则通常说明表索引不正确或写入的查询没有利用索引

    2、查看索引是否被使用到

    SELECT object_type, object_schema, object_name, index_name, count_star, count_read, COUNT_FETCH FROM PERFORMANCE_SCHEMA.table_io_waits_summary_by_index_usage;

    如果read,fetch的次数都为0的话,就是没有被使用过的。