mysql优化小结

目标:
掌握常见的优化方法
一. 如何通过慢日志发现有问题的sql?
(1)查询次数多且每次查询占用时间长的sql
通过pt-query-digest分析查询sql
(2)IO比较大的sql
通过pt-query-digest分析Rows examine项
(3)未命中索引的sql
通过pt-query-digest分析Rows examine项和Rows send对比
二.如何分析sql查询
通过explain sql;

EXPLAIN SELECT count(*) from mmall_cart
image.png

解析结果:
table:显示这一行的数据时关于那张表
type:显示连接使用了哪种类型,从嘴和到最差的链接类型为const、eq_req、ref、range、index和ALL。
possible_keys:显示可能应用在这张表的索引,如果为空,没索引。
key:实际使用的索引。
key_len:使用索引的长度,在不损坏精确性的情况下,索引的长度越短越好。
ref:显示索引被是使用。
rows:MYSQLr认为必须检查的用来返回请求数据的行数。
using filesort:出现这个则sql需要优化。MYSQL需要进行额外的步骤来发现如何对返回的行排序。他根据连接诶性一级存储排序键值和匹配条件的全部行的行指针来排序全部行。
using temporary:出现这个sql需要优化。MYSQL需要创建一个临时表存储结果。这通常发生在对不同的列集进行ORDER BY上而不是GROUP BY上。
三.常见sql优化
(1)max()优化

select  max(payment_date) from payment;
优化方式:创建索引
create index idx_paydate  on payment (payment_date)

(2)count()优化

count(id)代替count(*),count(id)查询不会查询null的数据

(3) limit优化

limit常用语分页处理,伴随着order by从句使用会出现IO问题。
select film_id,description from film order by title limit 50,5;
优化方法:
使用有索引的列或主键进行order by处理。
select film_id,description from film order by film_id limit 50,5;
记录上次返回的主键,在下次查询时使用主键过滤
select film_id,description from film where film_id>55 and film_id<60  order by film_id limit 1,5;

(4)如何选择合适的列建立索引?
在where从句,order by从句,order by从句,on从句出现的列
索引字段越小越好
离散度大的列放到联合索引的前面。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 数据库优化的目的 避免出现页面访问错误由于数据库连接timeout产生页面5xx错误由于慢查询造成页面无法加载由于...
    Hey_Shaw阅读 1,087评论 0 1
  • 今天看到一位朋友写的mysql笔记总结,觉得写的很详细很用心,这里转载一下,供大家参考下,也希望大家能关注他原文地...
    信仰与初衷阅读 4,767评论 0 30
  • 转 # https://www.cnblogs.com/easypass/archive/2010/12/ 08/...
    吕品㗊阅读 9,859评论 0 44
  • MYSQL 基础知识 1 MySQL数据库概要 2 简单MySQL环境 3 数据的存储和获取 4 MySQL基本操...
    Kingtester阅读 7,862评论 5 116
  • 引子 对于一条SQL,开发同学最先关心的啥? 我觉得还不到这个SQL在数据库的执行过程,而是这条SQL是否能尽快的...
    大头8086阅读 2,663评论 2 14