mysql慢sql优化

Posted

tags:

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

影响sql查询慢的因素

1、没有索引或则无效索引导致的全表扫描。
2、表的数据量和关联的表数量。

致索引无效的情况

1、表关联查询时,字段类型或长度不一致。如:varchar(10)和varchar(20)
2、查询参数的数据类型与索引字段类型不一致。如int = ‘1313‘
3、in () 索引字段in查询时,通常是有效的。但是当in中指定的数据太多,优化器认为全表扫描更快时,也不会使用索引。
4、其他如:like、索引上使用函数等使索引失效。

sql的执行顺序

from>join>on>where>group by>avg/sum>having>select>distinct>order by > limit

优化过程

优化的重点:使sql每一步筛选的数据更少,更快。
1、通过explain sql获取的信息:
第一个执行查询的表;索引的使用情况;每张表扫描到的数据条数;

2、通过select count(distinct cl)/count(1) from table,来查询关键查询字段的选择性。越大说明选择性越高,这种字段就应该优先建立索引。

3、analyze table 根据情况,分析table使其索引重建或则分布更加均衡。

4、如果查询优化后,反应出来的数据仍然很多,查询很慢。这时就应该根据业务来调整查询条件。

以上是关于mysql慢sql优化的主要内容,如果未能解决你的问题,请参考以下文章

Mysql优化之慢查询优化

MySQL面试常问问题(SQL 优化 ) —— 赶快收藏

MySQL如何定位并优化慢查询sql

MySQL优化--02----慢SQL定位慢查询日志

MySQL慢查询:慢SQL定位日志分析与优化方案

MySQL高级篇 - 性能优化