首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何识别哪些索引没有被使用?

如何识别哪些索引没有被使用?
EN

Stack Overflow用户
提问于 2010-05-25 05:08:20
回答 4查看 122关注 0票数 0

我在MySQL中有一个包含7个索引的表,其中大多数索引位于多个列上。我认为这里的索引太多了。有没有办法统计出对此数据库的数千次查询中哪些索引使用得更多,哪些索引的使用价值较低,这样我就可以知道首先应该考虑删除哪些索引?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2010-05-25 05:43:32

您可以尝试确定which indexes are used at all.

但是,就按有用性列出而言,对不起,没有内置的方法可以做到这一点,我认为Query Analyzer甚至不能做到这一点。

看起来您可能需要进行一次审计,以确定正在使用的影响该表的查询,并对这些查询进行解释,以查看它们是否使用了您的任何索引。

有一个错误报告requesting this feature

票数 3
EN

Stack Overflow用户

发布于 2010-06-03 22:13:31

您应该查看Percona补丁或其服务器版本。他们已经将表添加到INFORMATION_SCHEMA中,这样您就可以找到未使用的索引。

链接:

票数 1
EN

Stack Overflow用户

发布于 2010-05-25 05:13:36

这并不是一种具体的方法,但您也许能够分辨出来。尝试使用EXPLAIN SELECT...,它将向您显示正在使用的表、多少行等。这将为您提供足够的数据来加速您的表

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2900334

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档