mysql优化小结

作者: 优蜜 | 来源:发表于2019-04-21 20:29 被阅读13次

目标:
掌握常见的优化方法
一. 如何通过慢日志发现有问题的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从句出现的列
索引字段越小越好
离散度大的列放到联合索引的前面。

相关文章

  • MySQL优化小结

    数据库的配置是基础、SQL优化最重要(贯穿始终,每日必做),由图可知,越往上优化的面越小,最基本的SQL优化是最重...

  • mysql优化小结

    目标:掌握常见的优化方法一. 如何通过慢日志发现有问题的sql?(1)查询次数多且每次查询占用时间长的sql通过p...

  • 2021-08-09 MySQL性能优化总结

    MySQL性能优化层面 SQL和索引层面优化 Explain 小结 嵌套查询一般是从外到内进行;小表驱动大表 --...

  • MYSQL分页limit速度太慢优化方法

    MySQL 百万级分页优化(Mysql千万级快速分页)(转) MYSQL分页limit速度太慢优化方法 MYSQL...

  • MySQL相关文章索引(2)

    1.MySQL性能优化 对MySQL语句的性能分析与优化 Mysql 监控 Innodb 阻塞状况 MySQL索引...

  • 11-mysqlSQL分析

    六星教育 - java-mysql优化1909 SQL优化 所谓SQL优化:基于MySQL的优化器查询规则来优化S...

  • MySQL性能调优

    MYSQL查询语句优化 mysql的性能优化包罗甚广: 索引优化,查询优化,查询缓存,服务器设置优化,操作系统和硬...

  • mysql性能优化-慢查询分析、优化索引和配置

    mysql性能优化-慢查询分析、优化索引和配置 分类:Mysql/postgreSQL 目录 一、优化概述 二、查...

  • MYSQL优化相关

    mysql优化3大方向: 优化mysql所在服务器内核(运维完成)对mysql配置参数进行优化(my.cnf),此...

  • 第三个模块 MySQL-UUID、分词字典、MySQL全文索引

    论mysql5.7.13性能优化之索引优化mysql优化(1)show命令 慢查询日志 explain profi...

网友评论

    本文标题:mysql优化小结

    本文链接:https://www.haomeiwen.com/subject/fnljgqtx.html