MySQL 性能调优之索引

Posted 点影

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL 性能调优之索引相关的知识,希望对你有一定的参考价值。

原文:http://bbs.landingbj.com/t-0-245452-1.html

 

对于索引的优化,我们第一需要找到合适的字段,第二创建索引找到合适的顺序,第三要找到合适的比例,第四是要做合适的维护。

第一需要找到合适的字段。方法有:提高过滤性、降低索引的更新分裂、避免无效索引、非不得已不用外键。

在真实环境中,优化索引主要从以下方面考虑:

给索引的字段设置默认值;

不要让含NULL的字段进入组合索引;

删除过滤性低的字段的索引,可能性能更差;

不能在索引字段上做运算,会失效;

避免频繁更新的字段进入索引,增加IO负担;

尽量覆盖索引,因为mysql排序效率不高;

第二创建索引找到合适的顺序。方法有提早过滤、减少排序。

在真实环境中,优化索引主要从以下方面考虑:

过滤性越高的字段需要越靠前;

核心SQL覆盖索引,确保尽可能高效;

不干扰过滤前提下,排序字段进入索引;

多SQL综合考虑,重复利用索引;

第三要找到合适的比例,方法是控制索引长度,尤其是较长的字符串字段。

在真实环境中,优化索引主要从以下方面考虑:

必须回表取数据时,字符字段前缀索引;

不用回表取数据时,建议整个字段;

第四是要做合适的维护,方法是定期维护存在频繁增删改字段的索引。

在真实环境中,优化索引主要从以下方面考虑:

在可以的前提下,每月维护(重建)非核心表上的索引;

在可以的前提下,每季/年维护核心表上的索引。

在做DBA的过程中,才知道索引的优化对于一个系统而言是多么的重要。记住很重要的一条:索引不在多,而在于找到最合适的。

以上是关于MySQL 性能调优之索引的主要内容,如果未能解决你的问题,请参考以下文章

MySQL 性能调优之存储引擎

MySQL调优之EXPLAIN关键字

MYSQL数据库性能调优之三:explain分析慢查询

SQL性能调优之索引失效

Day809.MySQL调优之SQL语句 -Java 性能调优实战

MYSQL数据库性能调优之六:备份