如何MySQL优化总结_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

36d3a67f18a2

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从句出现的列

索引字段越小越好

离散度大的列放到联合索引的前面。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值