Distinct:一旦MYSQL找到了与行相联合匹配的行,就不再搜索了。

Not exists: MYSQL优化了LEFT JOIN,一旦它找到了匹配LEFT JOIN标准的行,就不再搜索了。

Range checked for each Record(index map:#):没有找到理想的索引,因此对于从前面表中来的每一个行组合,MYSQL检查使用哪个索引,并用它来从表中返回行。这是使用索引的最慢的连接之一。

Using index: 列数据是从仅仅使用了索引中的信息而没有读取实际的行动的表返回的,这发生在对表的全部的请求列都是同一个索引的部分的时候。

Using temporary

为了解决查询,MySQL需要创建一个临时表来容纳结果。典型情况如查询包含可以按不同情况列出                列的GROUP BY和ORDER BY子句时。

Using where

WHERE子句用于限制哪一个行匹配下一个表或发送到客户。除非你专门从表中索取或检查所有行,           如果Extra值不为Using where并且表联接类型为ALL或index,查询可能会有一些错误。

如果想要使查询尽可能快,应找出Using filesort 和Using temporary的Extra值。

1.mysql优化索引――Using filesort

用Explain分析SQL语句的时候,经常发现有的语句在Extra列会出现Using filesort,根据mysql官方文档对他的描述:

MySQL must do an extra pass to find out how to retrieve the rows in sorted order. The sort is done by going through all rows according to the join type and storing the sort key and pointer to the row for all rows that match the WHERE clause.

中文手册上翻译的很别扭:“Mysql需要额外的一次传递,以找出如何按排序顺序检索行,通过根据联接类型浏览所有行并为所有匹配where子句的行保存排序关键字和行的指针来完成排序,然后关键字被排序,并按排序顺序检索行。”

总的来说,Using filesort 是Mysql里一种速度比较慢的外部排序,如果能避免是最好的了,很多时候,我们可以通过优化索引来尽量避免出现Using filesort,从而提高速度。

这里举个简单的例子:

CREATE TABLE `testing` (

`id` int(10) unsigned NOT NULL auto_increment,

`room_number` int(10) unsigned NOT NULL default '0',

PRIMARY KEY   (`id`),

KEY `room_number` (`room_number`)

) ENGINE=MyISAM

DELIMITER $$

DROP PROCEDURE IF EXISTS  `askwan` $$

CREATE PROCEDURE `askwan` ()

BEGIN

DECLARE v INT DEFAULT 1;

WHILE v<100000DO

INSERT INTO testing VALUES(v,v);

SET v=v+1;

END WHILE;

END $$

DELIMITER ;

CALL askwan();

由上面例子中建立的表信息,我已经建立了两个索引,一个主键id,一个room_number列索引

那现在来看一条SQL

SELECT id FROM testing WHERE room_number=1000 ORDER BY id ;

出现了Using filesort,并且用到了room_number这列索引,但是,在这里用到的索引是针对WHERE后面的room_number条件的,而最后面的排序是根据id来的,这就是手册中说的,“额外的一次排序”!,于是就会出现Using filesort,根据我以前写过的一文章,我再建立一个联合索引 room_number_id。

alter table testing add index room_number_id(room_number,id);

mysql的extra,MySQL SQL优化-重点是 extra相关推荐

  1. mysql 执行计划extra_SQL优化 MySQL版 -分析explain SQL执行计划与Extra

    Extra 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 注:此文章必须有一定的Mysql基础,或观看执行计划入门篇传送门: https://www.cnblogs.com/Sta ...

  2. 超详细图解!【MySQL进阶篇】SQL优化-索引-存储引擎

    1. Mysql的体系结构概览 整个MySQL Server由以下组成 Connection Pool : 连接池组件 Management Services & Utilities : 管理 ...

  3. Mysql数据库高级、sql优化

    https://note.youdao.com/ynoteshare/index.html?id=53cd90b2a1d930e1f5c7558a3f595696&type=notebook& ...

  4. MySQL高级篇(SQL优化、索引优化、锁机制、主从复制)

    目录 0 存储引擎介绍 1 SQL性能分析 2 常见通用的JOIN查询 SQL执行加载顺序 七种JOIN写法 3 索引介绍 3.1 索引是什么 3.2 索引优劣势 3.3 索引分类和建索引命令语句 3 ...

  5. Mysql面试题,sql优化,存储引擎,数据结构,基础知识等

    目录 一.相关知识 什么是MySQL?SQL是什么? SQL的生命周期? 什么是超键.候选键.主键.外键? 数据库有哪几个范式,谈谈理解? MySQL的binlog有有几种录入格式?分别有什么区别? ...

  6. Mysql之快速上手sql优化

    一. 优化SQL步骤 在应用的的开发过程中,由于初期数据量小,开发人员写 SQL 语句时更重视功能上的实现,但是当应用系统正式上线后,随着生产数据量的急剧增长,很多 SQL 语句开始逐渐显露出性能问题 ...

  7. MySQL中常用的SQL优化方法

    SQL优化的方法有很多种,针对平时的情况总结一下几种: 以下用到的表和数据,可以通过这篇文章中的语句添加: MySQL执行计划explain的详解_蓝星部队的博客-CSDN博客一.如何查看SQL执行计 ...

  8. mysql多表查询sql优化_SQL多表查询优化

    SQL优化 1.执行路径:ORACLE的这个功能大大地提高了SQL的执行性能并节省了内存的使用:我们发现,单表数据的统计比多表统计的速度完全是两个概念.单表统计可能只要0.02秒,但是2张表联合统计就 ...

  9. mysql 索引,以及sql优化总结

    sql问题 where执行顺序 如果查询的所有条件都没有索引,则不分先后顺序(在500W数据下试过,没有太大差别),如果有索引,mysql会根据sql条件进行优化,比如先执行查询符合索引的条件. 下面 ...

最新文章

  1. mysql数据库千万级别数据的查询优化和分页测试
  2. Java程序员从笨鸟到菜鸟之(十二)java异常处理机制
  3. 徐州技师学院计算机程序设计,徐州技师学院2021年有哪些专业
  4. Linux vms windows,Windows、Windows NT、DOS、VMS、Linux都是微机上用的操作系统。
  5. Egret 生成 自带EUI 的微信小游戏 踩坑!
  6. .classpath文件有什么用_干货分享:Windows目录结构剖析,C盘目录常见文件夹都有什么用?...
  7. 奇人有奇书(李渔、张岱、陈继儒、吴敬梓)
  8. python支持复数以及相关的运算吗_Python复数属性和方法运算操作示例
  9. mysql数据库表格导出为excel表格
  10. m126a linux驱动下载,惠普HP LaserJet Pro M126a MFP 驱动
  11. MAVEN本地仓库安装及配置
  12. KindEditor
  13. Lync Server 2010下载拓扑报错分析及解决方法分享
  14. 倪光南:网络不安全要挨打 不用县县都建数据中心
  15. 外卖券-外卖优惠券-原生微信小程序
  16. 百练noi21:二维数组右上左下遍历,24:蛇形填充数组
  17. 超简单的vim配置高亮
  18. 网络安全-CTF取证方法大汇总,建议收藏!
  19. 一个高效的敏感词过滤方法(PHP)
  20. python写excel文件不覆盖_python excel多sheet存储,同sheet不覆盖追加数据

热门文章

  1. meta 标签的学习
  2. 收集数据至泛型Dictionary
  3. 线段树、优先队列、单调队列小结
  4. 转向与重定向的联系与区别
  5. 从零打造 Vue 聊天组件
  6. JavaScript学习笔记(二)--流程控制语句
  7. 机器学习中的数学(二)--梯度下降法
  8. 机器视觉开源代码集合(转载)
  9. Python内置函数总结
  10. 7-135 二叉搜索树的2层结点统计