mysql优化-索引

分类: MySQL

分析:

左连接索引建立在右表,就是建立相反键。
结论:join语句的优化
尽可能减少join语句中的NestedLoop的循环总次数:“永远用小结果集驱动大的结果集”。
优先优化NestedLoop的内层循环;
保证Join语句中被驱动表上Join条件字段已经被索引
当无法保证被驱动表的Join条件字段被索引且内存资源充足的情况下,不要太吝啬JoinBuffer的设置;

索引失效(应该避免)

1.全值匹配
2.最佳左前缀法则:如果索引了多列,要遵守最左前缀法则。指的是查询从索引的最左前列开始并且不跳过索引中的列
3.不在索引列上做任何操作(计算,函数,(自动or手动)类型转换,会导致索引失效而转向全表扫描)
4.存储引擎不能使用索引中范围条件右边的列,范围后全失效
5.尽量使用覆盖索引(只访问索引的查询(索引列和查询列一致)),减少select *
6.mysql在使用不等于(!=或者<>)的时候无法使用索引会导致全表扫描
7.is null, is not null 也无法使用索引
8.like以通配符开头('%abc')mysql索引失效会变成全表扫描的操作
可使用覆盖索引查询的方式解决使用双%%的问题
9.字符串不加单引号索引会失效
10.少用or,用它来连接时会索引失效

总结:定值、范围还是排序,一般order by是给个范围
group by 基本上都需要进行排序,会有临时表产生

一般性建议:

对于单键索引,尽量选择针对当前query过滤性更好的索引
在选择组合索引的时候,当前query中过滤性最好的字段在索引字段排序中,位置越靠前越好。
在选择组合索引的时候,尽量选择考研能够包含当前query中的where字句中更多字段的索引
尽可能通过分析统计信息和调整query的写法来达到选择合适索引的目的。

图片1.png

发表评论

您的电子邮箱地址不会被公开。 必填项已用*标注


Warning: error_log(/www/wwwroot/codegulu.cn/wp-content/plugins/spider-analyser/#log/log-1812.txt): Failed to open stream: Permission denied in /www/wwwroot/codegulu.cn/wp-content/plugins/spider-analyser/spider.class.php on line 2969