0. 准备

首先执行如下的 sql 语句:

CREATE TABLE IF NOT EXISTS `article` (`id` int(10) unsigned NOT NULL AUTO_INCREMENT,

`author_id` int(10) unsigned NOT NULL,

`category_id` int(10) unsigned NOT NULL,

`views` int(10) unsigned NOT NULL,

`comments` int(10) unsigned NOT NULL,

`title` varbinary(255) NOT NULL,

`content` text NOT NULL,

PRIMARY KEY (`id`)

);

INSERT INTO `article`

(`author_id`, `category_id`, `views`, `comments`, `title`, `content`) VALUES

(1, 1, 1, 1, '1', '1'),

(2, 2, 2, 2, '2', '2'),

(1, 1, 3, 3, '3', '3');

1. EXPLAIN 关键字

想要查询 category_id 为 1 且 comments 大于 1 的情况下,views 最多的 article_id。

语句如下(在传统的查询语句前加上 EXPLAIN 关键字):

EXPLAIN

SELECT author_id

FROM `article`

WHERE category_id = 1 AND comments > 1

ORDER BY views DESC

LIMIT 1;

给出如下的查询结果:

id: 1

select_type: SIMPLE

table: article

type: ALL

possible_keys: NULL

key: NULL

key_len: NULL

ref: NULL

rows: 3

Extra: Using where; Using filesort

1 row in set (0.00 sec)

2. EXPLAIN 关键字与 MySQL 查询优化器

MySQL 查询优化器有几个目标,但是其中最主要的目标是尽可能地使用索引,并且使用最严格的索引来消除尽可能多的数据行。

EXPLAIN 的每个输出行提供一个表的相关信息,并且每个行包括下面的列:

id:MySQL Query Optimizer 选定的执行计划中查询的序列号。表示查询中执行 SELECT 子句或操作表的顺序,id 值越大优先级越高,越先被执行。id 相同,执行顺序由上至下。

select_type 查询类型

SIMPLE:简单的 select 查询,不使用 union 及子查询

PRIMARY:最外层的 select 查询

UNION:UNION 中的第二个或随后的 select 查询,不 依赖于外部查询的结果集

DEPENDENT UNION:UNION 中的第二个或随后的 select 查询,依 赖于外部查询的结果集

SUBQUERY:子查询中的第一个 select 查询,不依赖于外 部查询的结果集

DEPENDENT SUBQUERY:子查询中的第一个 select 查询,依赖于外部 查询的结果集

DERIVED:用于 from 子句里有子查询的情况。 MySQL 会 递归执行这些子查询, 把结果放在临时表里。

UNCACHEABLE SUBQUERY:结果集不能被缓存的子查询,必须重新为外 层查询的每一行进行评估。

UNCACHEABLE UNION:UNION 中的第二个或随后的 select 查询,属 于不可缓存的子查询

table:输出行所引用的表

extra:中出现以下 2 项意味着 MYSQL 根本不能使用索引,效率会受到重大影响。应尽可能对此进行优化。

Using filesort:表示 MySQL 会对结果使用一个外部索引排序,而不是从表里按索引次序读到相关内容。可能在内存或者磁盘上进行排序。MySQL 中无法利用索引完成的排序操作称为“文件排序”

Using temporary:表示 MySQL 在对查询结果排序时使用临时表。常见于排序 order by 和分组查询 group by。

如果 EXPLAIN 的输出结果中,type 对应的是 ALL,extra 还出现了 Using filesort,都意味着 SQL 语句虽然能够工作,但其实是最坏的,并没有合理使用的 sql 查询语句。

3. 创建索引

ALTER TABLE `article` ADD INDEX x ( `category_id` , `comments`, `views` );

添加 INDEX 索引之后,再次调用 EXPLAIN 语句,可以看到,type 变成了 range,这是可以忍受的。但是 extra 里使用 Using filesort 仍是无法接受的。也即并未使用上面创建的索引。这是因为按照 BTree 索引的工作原理,先排序 category_id,如果遇到相同的 category_id 则再排序 comments,如果遇到相同的 comments 则再排序 views。当 comments 字段在联合索引里处于中间位置时,因comments > 1 条件是一个范围值,MySQL 无法利用索引再对后面的 views 部分进行检索,即 range 类型查询字段后面的索引无效。

DROP INDEX x ON article;

ALTER TABLE `article` ADD INDEX y ( `category_id` , `views` ) ;

mysql 优化关键字_MySQL 优化之 EXPLAIN 关键字相关推荐

  1. mysql优化方法_mysql优化方案总结

    u       Mysql数据库的优化技术 对mysql优化时一个综合性的技术,主要包括 a: 表的设计合理化(符合3NF) b: 添加适当索引(index) [四种: 普通索引.主键索引.唯一索引u ...

  2. mysql优化要点_MySQL优化技巧总结

    MySQL优化的几个大方向 ① 硬件优化 ② 对MySQL配置参数进行优化(my.cnf)此优化需要进行压力测试来进行参数调整 ③ SQL语句方面的优化 ④ 表方面的优化 硬件优化 cpu,内存,硬盘 ...

  3. mysql优化篇_MySQL优化篇-查询优化

    可以参考一下官方文档中的解释. 7. 优化 7.1. 优化概述 7.1.1. MySQL设计局限与折衷 7.1.2. 为可移植性设计应用程序 7.1.3. 我们已将MySQL用在何处? 7.1.4. ...

  4. 对mysql优化关注_MySQL优化看这篇就对了

    我们在面试的时候经常被问到你如何对数据库优化?动不动就分库分表,但是实际上有几个有分库分表的经验呢?下面我们将介绍优化数据库的各个阶段. 一.SQL语句优化 sql语句的优化是我们优化数据库的第一个阶 ...

  5. mysql 热块_mysql 优化

    数据库层面:应用系统层面优化SQL优化 SQL优化一般通过分析慢查询日志来抓取长事务高消耗的sql,通过结合具体业务,对sql逻辑进行分析and精简,or重写sql.通过配置slow_query_lo ...

  6. mysql 优化命令_MySQL优化Explain命令简介(一)

    最近碰到MySQL需要写入大量数据并查询的场景,于是学习了一下MySQL的查询优化,想找关于explain命令的详细资料,然而网上并没有找全,最后终于在<高性能MySQL>中找到了对这一命 ...

  7. mysql 优化版_MySQL优化(超完整版)(一)

    一. MySQL的优化 前言: MySQL数据库的优化模块: - 数据库的设计-三大范式 - 数据库的索引:唯一索引.主键索引.聚合索引.复合索引.默认索引 - SQL优化 - 分库分表 - 读写分离 ...

  8. mysql优化难_mysql优化注意点

    通常和zerofill一起使用,比如int(3),存入1,则自动填充为001.并不是存入的长度 char(n),varchar(n)中的n是最大长度. 外键索引一般不用,可以通过业务逻辑来实现.全文索 ...

  9. 物理机存放mysql实例原则_MySQL优化笔记(四)--表的设计与优化(单表、多表)...

    前面讲了SQL优化以及索引的使用.设计优化了,那么接下来就到表的设计与优化啦!!!真实地去设计优化单表结构以及讲述多表设计基本原则(结合真实的生产环境的取舍来讲述). 文章结构:(1)单表设计与优化: ...

最新文章

  1. python学习干货教程(10):列表
  2. mysql开启skip-name-resolve 导致root@127.0.0.1(localhost)访问引发的ERROR 1045 (28000)错误解决方案...
  3. 背景透明的 Dialog
  4. mysql进阶(十五) mysql批量删除大量数据
  5. 【IT笔试面试题整理】数组中出现次数超过一半的数字
  6. 使用JNA的透明JFrame
  7. 【转】ABP源码分析六:依赖注入的实现
  8. 利用域名(host碰撞)碰撞实现从任何地方发起中间人攻击(理论篇)
  9. 计算机考试属于相对性评价还是绝对性评价,【易错检测】查漏补缺第46天 — 相对性评价与绝对性评价...
  10. 一款用了都说好的思维导图软件:Ayoa
  11. android 滤镜录制,Android Camera 实时滤镜
  12. 最新投影圣经投影赞美诗歌圣经诗歌2020
  13. 双目视觉摄像机的参数标定参考坐标系介绍
  14. 五行俱全才能成为合格的游戏系统策划!
  15. 寻宝游戏设定_第1集的答案(寻宝游戏)
  16. input输入框无法输入值的解决方案
  17. 基于LMS算法的DFE判决反馈均衡器
  18. 基于ssm+shiro+activiti的办公自动化系统
  19. 微软下载中心使用Silverlight搜索
  20. 七夕祭( Poetize系列)

热门文章

  1. 配置php7开发环境,Windows7系统环境安装配置PHP开发环境
  2. 判断点在直线的哪一侧_【倒车入库】车身是否“正直”该怎么判断?
  3. java 操作vss,java开发常用工具总结,java开发常用工具
  4. java求值不用后缀表达式_数据结构之后缀表达式求值(java实现)
  5. python对象特性教学_Python三个面向对象特性多态性的实用解释,实践,解读,丨,三大,特征,之...
  6. java查找一个数等于一组数中哪些数字相加的和_快速入门二分查找
  7. 惠普m154a状态页_惠普新品NS—1005w无线智能应用与驱动安装篇
  8. python字符串的删除操作_Python 字符串操作(string替换、删除、截取、复制、连接、比较、...
  9. java stream Interface Collector<T,A,R>
  10. Spring mvc @RequestHeader