zoukankan      html  css  js  c++  java
  • Explain分析查询语句

    ​表的读取顺序

    读取操作的类型

    可用索引,实际使用的索引

    表之间的引用

    每张表多少行被优化器查询

    索引的长度


    EXPLAIN字段解释:

    ØTable:显示这一行的数据是关于哪张表的

    Øpossible_keys:显示可能应用在这张表中的索引。如果为空,没有可能的索引。可以为相关的域从WHERE语句中选择一个合适的语句

    Økey:实际使用的索引。如果为NULL,则没有使用索引。MYSQL很少会选择优化不足的索引,此时可以在SELECT语句中使用USE INDEX(index)来强制使用一个索引或者用IGNORE INDEX(index)来强制忽略索引

    Økey_len:使用的索引的长度。在不损失精确性的情况下,长度越短越好

    Øref:显示索引的哪一列被使用了,如果可能的话,是一个常数

    Ørows:MySQL认为必须检索的用来返回请求数据的行数

    Øtype:这是最重要的字段之一,显示查询使用了何种类型。从最好到最差的连接类型为system、const、eq_reg、ref、range、index和ALL

    system、const:可以将查询的变量转为常量. 如id=1; id为 主键或唯一键.

    eq_ref:访问索引,返回某单一行的数据.(通常在联接时出现,查询使用的索引为主键或惟一键)

    ref:访问索引,返回某个值的数据.(可以返回多行) 通常使用=时发生

    range:这个连接类型使用索引返回一个范围中的行,比如使用>或<查找东西,并且该字段上建有索引时发生的情况(注:不一定好于index)

    index:以索引的顺序进行全表扫描,优点是不用排序,缺点是还要全表扫描

    ALL:全表扫描,应该尽量避免

    ØExtra:关于MYSQL如何解析查询的额外信息,主要有以下几种

    using index:只用到索引,可以避免访问表.

    using where:使用到where来过虑数据. 不是所有的where clause都要显示using where. 如以=方式访问索引.

    using tmporary:用到临时表

    using filesort:用到额外的排序. (当使用order by v1,而没用到索引时,就会使用额外的排序)

    range checked for eache record(index map:N):没有好的索引.


    显示mysql如何使用索引来处理select语句以及连接表。

    可以帮助选择更好的索引和写出更优化的查询语句。


    简述:

    使用 EXPLAIN 或DESC关键字可以模拟优化器执行SQL查询语句,从而知道MySQL是如何处理你的SQL语句的。这可以帮你分析你的 查询语句 或是 表结构的性能 瓶颈。

    通过explain命令可以得到:

    1、表的读取顺序

    2、表的读取操作的操作类型

    3、哪些索引可以使用

    4、哪些索引被实际使用

    5、表之间的引用

    6、每张表有多少行被优化器查询

    为什么要使用explain :

    explain可以帮助我们分析 select 语句,让我们知道查询效率低下的原因,从而改进我们查询,让查询优化器能够更好的工作。

    MySQL查询优化器是如何工作的 :

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

    最终目标是提交SELECT语句查找数据行,而不是排除数据行。

    优化器试图排除数据行的原因在于它排除数据行的速度越快,那么找到与条件匹配的数据行也就越快。

    如果能够首先进行最严格的测试,查询就可以执行地更快。

    explain局限 :

    1、explain不会告诉你关于触发器,存储过程的信息或者用户自定义的函数对查询的影响情况。

    2、explain不会考虑cache。


  • 相关阅读:
    POJ 3140 Contestants Division (树dp)
    POJ 3107 Godfather (树重心)
    POJ 1655 Balancing Act (树的重心)
    HDU 3534 Tree (经典树形dp)
    HDU 1561 The more, The Better (树形dp)
    HDU 1011 Starship Troopers (树dp)
    Light oj 1085
    Light oj 1013
    Light oj 1134
    FZU 2224 An exciting GCD problem(GCD种类预处理+树状数组维护)同hdu5869
  • 原文地址:https://www.cnblogs.com/lsx1993/p/4793168.html
Copyright © 2011-2022 走看看