mysql学习-explain

表头包含有:

id---select_type---table---type---possible_keys---key---key_len---ref---rows---Extra

  • id:select 查询的序列号,包含一组数字,表示查询中执行select子句或操作表的顺序,分为三种情况:

    三种情况:
    1.id相同,执行顺序由上至下
    2.id不同,如果是子查询,id的序号会递增,id值越大优先级越高,越先被执行
    3.id相同不同,id大的先执行,同级为由上到下
    DERIVED  衍生
  • select_type
    simple:简单的select查询,查询中不包含子查询或者union
    primary:查询中若包含任何复杂的子部分,最外层查询则被标记为
    subquery:在select或where列表中包含了子查询
    derived:在from列表中包含的子查询被标记为derived,mysql会递归执行这些子查询,把结果放在临时表里.
    union:若第二个select出现在union之后,刚被标记为union,若union包含在from子句的子查询中,外层的select 将被标记为derived
    union result:从union表中获取结果的select
  • type
    all:full table scan,遍历全表以找到匹配的行
    index:full index scan,index与all区别index类型只遍历索引树,这通常比all快,因为索引文件通常比数据文件小,
    range:只检索给定范围的行,使用一个索引来选择行,key列显示使用了哪个索引,一般就是在你的where语句中出现了between\<\>\in等的查询,这种范围扫描索引扫描比全表扫描要好,因为它只需要开始于索引的某一点,而结束于另一点,不用扫描全部索引,
    ref:非唯一性索引扫描,返回匹配某个单独值的所有行,本质上也是一种索引访问,它返回所有匹配某个单独值 的行,然而,它可能 会找到多个符合条件的行,所以他应该属于查找和扫描的混合体
    eq_ref:唯一索引扫描,对于每个索引键,表中只有一条记录与之匹配。常见于主键或唯一索引扫描
    system:表中只有一行记录,这是const类型的特例,平时不会出现,这个忽略不计
    const:表示通过索引一次就可以找到,const用于比较primary key 或者unique索引,因为只匹配一行数据,所以快,如果主键置于where列表中,mysql就能将该查询转换为一个常量
    null:
    system>const>eq_ref>ref>range>index>all
  • possible_keys,key,key_len
    pessible_keys:显示可能应用到这张表中的索引,一个或多个,查询涉及到的字段上若存在索引,则索引将被列出,但不一定被查询实际使用
    key:实际使用的索引,如果为null,则没有使用索引,查询中若使用了覆盖索引,则该索引仅出现在key列表 中key_len:显示的值为索引字段的最大可能长度,并非实际使用长度,即key_len是根据表定义计算而得,不是通过表内检索出的
  • ref
    显示索引的哪一列被使用了,如果可能 的话,是一个常数,哪些列或常量被用于查找索引列上的值
  • rows
    根据表统计信息及索引选用情况,大致估算出找到所需的记录所需要读取的行数

原文地址:https://www.cnblogs.com/javage/p/9385986.html

时间: 2024-10-20 09:21:11

mysql学习-explain的相关文章

MySQL学习----explain查看一条sql 的性能

在开发的过程中,对于我们写的sql语句,我们有时候会考虑sql语句的性能,那么explain就是首选.Explain命令在解决数据库性能上是第一推荐使用命令,大部分的性能问题可以通过此命令来简单的解决,Explain可以用来查看 SQL 语句的执行效 果,可以帮助选择更好的索引和优化查询语句,写出更好的优化语句. Explain语法:explain select - from - [where ...] 例如:explain select * from news; 输出: +----+-----

mysql学习-explain中的extra

覆盖索引就是创建的索引和查询的字段正好个数顺序一致 using filesort:mysql使用了一个外部索引 ,而非表内索引顺序进行访问,,mysql无法利用索引完成的排序操作称为文件索引,如果你创建了索引,但并没按索引个数顺序进行查询就会出现 using temporary:使用了临时保存中间结果,mysql在对查询结果排序时使用临时表,常见于排序order by 和分组查询group by . using index:使用了覆盖索引 原文地址:https://www.cnblogs.com

MySQL学习系列2--MySQL执行计划分析EXPLAIN

1.Explain语法 EXPLAIN SELECT -- 变体:   EXPLAIN EXTENDED SELECT -- 将执行计划"反编译"成SELECT语句,运行SHOW WARNINGS 可得到被MySQL优化器优化后的查询语句 2.执行计划分析和实例 创建员工表Employee create table Employee ( ID int auto_increment, Ename varchar(32), Age int, Salary float, MID int, P

mysql 学习笔记 第二天

插入表格数据: Insert into table_name set columns_1=value1,columns_2=value2,对于没有赋值的列,将会取默认值,并且这个方法只能一次插入一个数据 利用文本方式插入数据: Load data local infile‘径’into table table_name: Select 的通用形式: Select columns from table or tables where conditions;from一般不能少的,但是当查询的时候没有

详解MySQL中EXPLAIN解释命令

Explain 结果解读与实践 基于 MySQL 5.0.67 ,存储引擎 MyISAM . 注:单独一行的"%%"及"`"表示分隔内容,就象分开“第一章”“第二章”. explain 可以分析 select 语句的执行,即 MySQL 的“执行计划”: mysql> explain select 1; +----+-------------+-------+------+---------------+------+---------+------+----

我的MYSQL学习心得(十六)

我的MYSQL学习心得(十六) 我的MYSQL学习心得(一) 我的MYSQL学习心得(二) 我的MYSQL学习心得(三) 我的MYSQL学习心得(四) 我的MYSQL学习心得(五) 我的MYSQL学习心得(六) 我的MYSQL学习心得(七) 我的MYSQL学习心得(八) 我的MYSQL学习心得(九) 我的MYSQL学习心得(十) 我的MYSQL学习心得(十一) 我的MYSQL学习心得(十二) 我的MYSQL学习心得(十三) 我的MYSQL学习心得(十四) 我的MYSQL学习心得(十五) 一步一步

我的MYSQL学习心得(九)

我的MYSQL学习心得(九) 我的MYSQL学习心得(一) 我的MYSQL学习心得(二) 我的MYSQL学习心得(三) 我的MYSQL学习心得(四) 我的MYSQL学习心得(五) 我的MYSQL学习心得(六) 我的MYSQL学习心得(七) 我的MYSQL学习心得(八) 这一篇<我的MYSQL学习心得(九)>将会讲解MYSQL的索引 索引是在存储引擎中实现的,因此每种存储引擎的索引都不一定完全相同,并且每种存储引擎也不一定支持所有索引类型. 根据存储引擎定义每个表的最大索引数和最大索引长度.所有

我的MYSQL学习心得(九) 索引

这一篇<我的MYSQL学习心得(九)>将会讲解MYSQL的索引 索引是在存储引擎中实现的,因此每种存储引擎的索引都不一定完全相同,并且每种存储引擎也不一定支持所有索引类型. 根据存储引擎定义每个表的最大索引数和最大索引长度.所有存储引擎支持每个表至少16个索引,总索引长度至少为256字节. 大多数存储引擎有更高的限制.MYSQL中索引的存储类型有两种:BTREE和HASH,具体和表的存储引擎相关: MYISAM和InnoDB存储引擎只支持BTREE索引:MEMORY和HEAP存储引擎可以支持H

Mysql学习笔记(八)索引

原文:Mysql学习笔记(八)索引 PS:把昨天的学习内容补上...发一下昨天学的东西....五月三日...继续学习数据库... 学习内容: 索引.... 索引的优点: 1.通过创建唯一索引,可以保证数据库每行数据的唯一性... 2.使查找的速度明显加快... 3.当使用分组和排序进行查询时,可以缩短时间... 索引的缺点: 1.维护索引需要耗费数据库的资源... 2.索引需要占用磁盘空间... 3.对表进行增删改的时候,由于索引的存在,时间会有所增加... 索引的分类... 普通索引和唯一索引