首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

(4) MySQL中EXPLAIN执行计划分析

SELECT_TYPE列 值 含义 SIMPLE 不包含子查询或是UNION操作的查询 PRIMARY 查询中如果包含任何子查询,那么最外层的查询则被标记为PRIMARY SUBQUERY SELECT...列表中的子查询 DEPENDENT SUBQUERY 依赖外部结果的子查询 UNION Union操作的第二个或是之后的查询的值为union DEPENDENT UNION 当UNION作为子查询时,...TYPE列 按性能从高至低排列如下: 值 含义 system 这是const联接类型的一个特例,当查询的表只有一行时使用 const 表中有且只有一个匹配的行时使用,如对主键或是唯一索引的查询,这是效率最高的联接方式...POSSIBLE_KEYS列 指出MySQL能使用哪些索引来优化查询 查询列所涉及到的列上的索引都会被列出,但不一定会被使用 8....Ref列 表示当前表在利用Key列记录中的索引进行查询时所用到的列或常量 11. rows列 表示MySQL通过索引的统计信息,估算出来的所需读取的行数(关联查询时,显示的是每次嵌套查询时所需要的行数)

92920

MySQL索引

8.小表不应建立索引;   包含大量的列并且不需要搜索非空值的时候可以考虑不建索引 索引的分类 主键索引 主键索引:只能有一个主键。...这个不重要,查询序号即为sql语句执行的顺序 id相同,执行顺序由上至下 如果是子查询,id的序号会递增,id值越大优先级越高,越先被执行 id如果相同,可以认为是一组,从上往下顺序执行;在所有组中,id...显而易见的索引范围扫描是带有between或者where子句里带有查询。当mysql使用索引去查找一系列值时,例如IN()和OR列表,也会显示range(范围扫描),当然性能上面是有差异的。...许多where条件里涉及索引中的列,当(并且如果)它读取索引时,就能被存储引擎检验,因此不是所有带where字句的查询都会显示"Using where"。..., in null时 必须要和建立索引第一列一起使用,当建立索引第一位置条件是is null 时,其他建立索引的列可以是is null(但必须在所有列 都满足is null的时候),或者=一个值; 当建立索引的第一位置是

3.9K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL 8.0.24 发布

    如果子查询已经具有显式分组,则MySQL会将额外的分组添加到现有分组列表的末尾。 MySQL执行基数检查,以确保子查询返回的行不超过一行,ER_SUBQUERY_NO_1_ROW如果返回则进行查询 。...(缺陷#32127912) InnoDB: 对父表执行的删除操作在具有索引虚拟列和索引外键约束列的子表上启动级联更新导致虚拟列损坏。...此修复程序通过允许在字段引用可以出现在可以使用多值索引的上下文中(即,当它们出现在上下文中)时替换列引用,从而解除了服务器尝试用索引生成的列仅替换函数表达式和条件表达式的限制。...(缺陷#32239578) 仅检索不可见列的自然联接的表子查询未正确处理。(缺陷#32235285) 对于调试版本,ALTER TABLE用于将列设置为具有 引发断言的 DEFAULT值TRUE。...NULL不具有子查询的情况下返回做到了。

    3.7K20

    MySQL8.0.30 release note 中文翻译(详细版)

    重要变化 当不止一种语言具有相同的排序规则定义时,MySQL 只为其中一种语言实现排序规则。这意味着某些语言仅由特定于其他语言的 utf8mb4 Unicode 9.0 排序规则覆盖。...以前,在升级期间,该权限不授予任何数据库用户。(Bug #33854409) 一个相关的子查询没有按照预期使用功能索引。...这发生在子查询内部使用的外部列引用没有被视为子查询执行的常量,这使得对功能索引的考虑被跳过。 我们通过确保在执行子查询时将外部列引用视为常量来解决这个问题。...(Bug #106824, Bug #33997819) 在某些情况下,当子查询的WHERE子句包含一个等价物时,执行具有物化功能的半联接可能导致不正确的结果。...在某些情况下,例如当这种等价关系的一方是IN或NOT IN子查询时,该等价关系既没有被下推到物化子查询中,也没有作为半联接的一部分被评估。这也导致了一些内部哈希连接的问题。

    2K10

    实战讲解MySQL执行计划,面试官当场要了我

    当查询仅使用属于单个索引一部分的列时,MySQL可以使用此连接类型。 explain select title from film; 1.4.3 range 使用索引查询行,仅检索给定范围内的行。...当使用 =, , >, >=, , BETWEEN, LIKE, or IN()操作符将key列与常量进行比较时,可以使用range: 索引范围扫描,常见当连接使用索引的所有部分并且索引是PRIMARY KEY或UNIQUE NOT NULL索引时,将使用它。...因为只有一行,所以优化器的其余部分可以将这一行中列的值视为常量。 const表非常快,因为它们仅读取一次。 当将PRIMARY KEY或UNIQUE索引的所有部分与常量值进行比较时,将使用const。...ORDER BY子句: Extra列不包含Using filesort,则使用索引,并且不执行文件排序 Extra列包含Using filesort,则不使用索引,而是执行全文件的排序 ?

    1.3K10

    MySQL Explain详解

    ) (6) SUBQUERY(子查询中的第一个SELECT) (7) DEPENDENT SUBQUERY(子查询中的第一个SELECT,取决于外面的查询) (8) DERIVED(派生表的SELECT...system: 当MySQL对查询某部分进行优化,并转换为一个常量时,使用这些类型访问。...如将主键置于where列表中,MySQL就能将该查询转换为一个常量,system是const类型的特例,当查询的表只有一行的情况下,使用system NULL: MySQL在优化过程中分解语句,执行时甚至不用访问表或索引...五、possible_keys 指出MySQL能使用哪个索引在表中找到记录,查询涉及到的字段上若存在索引,则该索引将被列出,但不一定被查询使用 该列完全独立于EXPLAIN输出所示的表的次序。...)* 不损失精确性的情况下,长度越短越好 八、ref 表示上述表的连接匹配条件,即哪些列或常量被用于查找索引列上的值 九、rows 表示MySQL根据表统计信息及索引选用情况,估算的找到所需的记录所需要读取的行数

    1.1K10

    mysql之引擎、Explain、权限详解

    但是该引擎不支持FULLTEXT类型的索引,而且它没有保存表的行数,当SELECT COUNT(*) FROM TABLE时需要扫描全表。当需要使用数据库事务时,该引擎当然是首选。...如果是子查询,id的序号会递增,id值越大优先级越高,越先被执行 3.id如果相同,可以认为是一组,从上往下顺序执行;在所有组中,id值越大,优先级越高,越先执行 二、select_type 示查询中每个...的结果) (6) SUBQUERY(子查询中的第一个SELECT) (7) DEPENDENT SUBQUERY(子查询中的第一个SELECT,取决于外面的查询) (8) DERIVED(派生表的SELECT...system: 当MySQL对查询某部分进行优化,并转换为一个常量时,使用这些类型访问。...五、possible_keys 指出MySQL能使用哪个索引在表中找到记录,查询涉及到的字段上若存在索引,则该索引将被列出,但不一定被查询使用 该列完全独立于EXPLAIN输出所示的表的次序。

    1.2K40

    MYSQL EXPLAIN结果详解

    1 id select的识别符,这是select的查询序列号。 如果有两列数据id相同,则为同一组查询,由上到下执行。 如果id值不同,id值越大,优先级越高。...当MySQL对查询某部分进行优化,并转换为一个常量时,使用这些类型( system/const )访问。如将主键置于where列表中,MySQL就能将该查询转换为一个常量。...当查询的表只有一行的情况下,使用system。 const:表最多有一个匹配行,它将在查询开始时被读取。因为仅有一行,在这行的列值可被优化器剩余部分认为是常数。...要想强制MySQL使用或忽视possible_keys列中的索引, 在查询中使用FORCE INDEX、USE INDEX或者IGNORE INDEX。...8 key_len 索引的长度 ( 使用的字节数 )。如果索引是NULL,则长度为NULL。 不损失精确性的情况下,长度越短越好 。

    2.6K30

    启用MySQL查询缓存

    如果是子查询,id的序号会递增,id值越大优先级越高,越先被执行   3.id如果相同,可以认为是一组,从上往下顺序执行;在所有组中,id值越大,优先级越高,越先执行 select_type 示查询中每个...的结果) (6) SUBQUERY(子查询中的第一个SELECT) (7) DEPENDENT SUBQUERY(子查询中的第一个SELECT,取决于外面的查询) (8) DERIVED(派生表的SELECT...key作为关联条件 const、system: 当MySQL对查询某部分进行优化,并转换为一个常量时,使用这些类型访问。...如将主键置于where列表中,MySQL就能将该查询转换为一个常量,system是const类型的特例,当查询的表只有一行的情况下,使用system NULL: MySQL在优化过程中分解语句,执行时甚至不用访问表或索引...) 不损失精确性的情况下,长度越短越好 ref 表示上述表的连接匹配条件,即哪些列或常量被用于查找索引列上的值 rows 表示MySQL根据表统计信息及索引选用情况,估算的找到所需的记录所需要读取的行数

    2.1K30

    【mysql系列】细谈explain执行计划之“谜”

    从图中ID列,我们看到ID=2的先执行即先查询teacher表。 select_type simple 简单的select查询,查询中不包含子查询或者UNION; ?...table 输出的行所引用的表; 当 from 子句中有子查询时,table列是 格式,表示当前查询**依赖 id=N **的查询,于是先执行 id=N 的查询。 ?...当有 union 时,UNION RESULT 的 table 列的值为,1和2表示参与 union 的 select行id。 ?...这可能是在 const 之外最好的连接类型了,简单的 select 查询不会出现这种 type。 ? id列都是1,当id列值一样时,从上到下执行表。...索引最大长度是768字节,当字符串过长时,MySql会做一个类似左前缀索引的处理,将前半部分的字符提取出来做索引。

    91710

    Mysql Explain 详解

    如果是子查询,id的序号会递增,id值越大优先级越高,越先被执行 3.id如果相同,可以认为是一组,从上往下顺序执行;在所有组中,id值越大,优先级越高,越先执行 二、select_type 示查询中每个...的结果) (6) SUBQUERY(子查询中的第一个SELECT) (7) DEPENDENT SUBQUERY(子查询中的第一个SELECT,取决于外面的查询) (8) DERIVED(派生表的SELECT...system: 当MySQL对查询某部分进行优化,并转换为一个常量时,使用这些类型访问。...如将主键置于where列表中,MySQL就能将该查询转换为一个常量,system是const类型的特例,当查询的表只有一行的情况下,使用system NULL: MySQL在优化过程中分解语句,执行时甚至不用访问表或索引...五、possible_keys 指出MySQL能使用哪个索引在表中找到记录,查询涉及到的字段上若存在索引,则该索引将被列出,但不一定被查询使用 该列完全独立于EXPLAIN输出所示的表的次序。

    1.1K20

    MySQL-explain笔记

    当使用主键索引(PRIMARY KEY)或不为空的唯一索引(UNIQUE NOT NULL index) const 该表最多具有一个匹配行,该行在查询开始时读取。...5.2 range 当使用=、 、>、>=、、BETWEEN 或者 IN 操作符,用常量比较关键字列时,可以使用 range 5.3 ref 如果联接只使用键的最左边的前缀...当possible_keys中没有适合的索引,但是该查询的所有列都是某个索引的列,即索引覆盖了选定的列,此时尽管不使用索引来确定要检索的行,但索引扫描依旧比数据行扫描更高效。...8. key_len MySQL决定使用的key的长度,即MySQL在索引里使用的字节数,它包含了在索引字段中可能的最大长度,而不是表中使用的实际字节数。...Using index 仅使用索引树中的信息从表中检索列信息,而不必进行其他查找以读取实际行。当查询仅使用属于单个索引的列时,可以使用此策略。

    2.3K10

    实战讲解MySQL的expain执行计划,面试官当场要了我

    当查询仅使用属于单个索引一部分的列时,MySQL可以使用此连接类型。 explain select title from film; 1.4.3 range 使用索引查询行,仅检索给定范围内的行。...当使用 =, , >, >=, , BETWEEN, LIKE, or IN()操作符将key列与常量进行比较时,可以使用range: 索引范围扫描,常见当连接使用索引的所有部分并且索引是PRIMARY KEY或UNIQUE NOT NULL索引时,将使用它。...因为只有一行,所以优化器的其余部分可以将这一行中列的值视为常量。 const表非常快,因为它们仅读取一次。 当将PRIMARY KEY或UNIQUE索引的所有部分与常量值进行比较时,将使用const。...使用EXPLAIN可以检查MySQL是否可以使用索引来解析ORDER BY子句: Extra列不包含Using filesort,则使用索引,并且不执行文件排序 Extra列包含Using filesort

    79150

    mysql慢查询优化方法_MySQL查询优化

    ,可能是简称 type 表示表的连接类型 possible_keys 表示查询时,可能使用的索引 key 表示实际使用的索引 key_len 索引字段的长度 ref 列与索引的比较,表示表的连接匹配条件...子句的类型(简单 OR 复杂) select_type 含义 SIMPLE 简单的 SELECT 查询,查询中不包含子查询或者 UNION PRIMARY 查询中若包含任何复杂的子查询,最外层查询标记为该标识...,当查询的表只有一行的情况下,使用 system NULL MySQL 在优化过程中分解语句,执行时甚至不用访问表或索引 从上到下,性能从差到好,一般来说需要保证查询至少达到 range 级别, 最好达到...ref ---- key possible_keys: 指出 MySQL 能使用哪个索引在表中找到记录,查询涉及到的字段上若存在索引,则该索引将被列出,但不一定被查询使用 如果该列是 NULL,则没有相关的索引...condition:第一种情况是搜索条件中虽然出现了索引列,但是有部分条件无法使用索引,会根据能用索引的条件先搜索一遍再匹配无法使用索引的条件,回表查询数据;第二种是使用了索引下推 Using

    14.6K40

    MySQl索引(二)如何看懂explain工具信息,使用explain工具来分析索引

    select_type:select 的查询类型,表示对应行是简单查询还是复杂查询,该类型的值如下表。 最常见的几种类型: simple:简单查询,即查询语句中不包含子查询和 union。...当 from 子句中存在子查询时,该列是 derivenN 格式的,表示当前查询依赖 id=N 的查询,会先执行 id=N 的查询。...ref:当满足索引的最左前缀规则,或者索引不是主键也不是唯一索引时才会发生。如果使用的索引只会匹配到少量的行,性能也是不错的。...index:全索引扫描,和ALL类似,只不过index是全盘扫描了索引的数据。当查询仅使用索引中的一部分列时,可使用此类型。...key_len:当前查询 mysql 在索引中使用的字节数,我们可以通过判断该值的大小算出使用索引的具体列。

    25210

    mysql explain ref null_MySQL Explain详解

    ;在所有组中,ID值越大,优先级越高,越先执行 二、select_type 示查询中每个select子句的类型 SIMPLE:简单的SELECT,不实用UNION或者子查询。...当连接使用索引的所有部分且索引是 索引PRIMARY KEY或UNIQUE NOT NULL索引时使用它。...当查询仅使用属于单个索引的列时,MySQL可以使用此连接类型。 ALL 对前面表格中的每个行组合进行全表扫描。如果表是第一个未标记的表 const,通常不好,并且在所有其他情况下通常 非常糟糕。...如果是这样,创造一个适当的索引并且再次用EXPLAIN检查查询 六、Key key列显示MySQL实际决定使用的键(索引) 如果没有选择索引,键是NULL。...要想强制MySQL使用或忽视possible_keys列中的索引,在查询中使用FORCE INDEX、USE INDEX或者IGNORE INDEX。

    1.8K40

    MySQL Explain查看执行计划

    所以我们深入了解MySQL的基于开销的优化器,还可以获得很多可能被优化器考虑到的访问策略的细节,以及当运行SQL语句时哪种策略预计会被优化器采用。...system: 当MySQL对查询某部分进行优化,并转换为一个常量时,使用这些类型访问。...如将主键置于where列表中,MySQL就能将该查询转换为一个常量,system是const类型的特例,当查询的表只有一行的情况下,使用system NULL: MySQL在优化过程中分解语句,执行时甚至不用访问表或索引...五、possible_keys 指出MySQL能使用哪个索引在表中找到记录,查询涉及到的字段上若存在索引,则该索引将被列出,但不一定被查询使用 该列完全独立于EXPLAIN输出所示的表的次序。...) 不损失精确性的情况下,长度越短越好 八、ref 表示上述表的连接匹配条件,即哪些列或常量被用于查找索引列上的值 九、rows 表示MySQL根据表统计信息及索引选用情况,估算的找到所需的记录所需要读取的行数

    1.9K30

    面试前必须知道的MySQL命令【expalin】

    explain一下拥有子查询的SQL 1.3.2select_type 表示select查询的类型 select_type属性下有好几种类型: SIMPLLE:简单查询,该查询不包含 UNION 或子查询...当from子句中有子查询时,table列是 格式,表示当前查询依赖 id=N的查询,于是先执行 id=N 的查询 1.3.4type 该列称为关联类型或者访问类型,它指明了MySQL...这个类型通常出现在 =、<>、>、>=、、BETWEEN、IN() 的操作中,key 列显示使用了哪个索引,当 type 为该值时,则输出的 ref...1.3.5possible_keys 这一列显示查询可能使用哪些索引来查找 1.3.6key 这一列显示MySQL实际决定使用的索引。如果没有选择索引,键是NULL。...1.3.7key_len 这一列显示了在索引里使用的字节数,当key列的值为 NULL 时,则该列也是 NULL 1.3.8ref 这一列显示了哪些字段或者常量被用来和key配合从表中查询记录出来。

    1K20

    MYSQL优化有理有据全分析(面试必备)

    注意:key_len是确定了MySQL将实际使用的索引长度。 ref 显示使用哪个列或常数与key一起从表中选择行。 rows 显示MySQL认为它执行查询时必须检查的行数。...使用索引查询需要注意 索引可以提供查询的速度,但并不是使用了带有索引的字段查询都会生效,有些情况下是不生效的,需要注意!...使用OR关键字的查询 查询语句的查询条件中只有OR关键字,且OR前后的两个条件中的列都是索引时,索引才会生效,否则,索引不生效。 ? ? ?...执行子查询时,MYSQL需要创建临时表,查询完毕后再删除这些临时表,所以,子查询的速度会受到一定的影响。...因为当一个表的数据量很大时,会由于使用频率低的字段的存在而变慢。 增加中间表 对于需要经常联合查询的表,可以建立中间表以提高查询效率。

    1.3K30

    看了这篇MySQL,开发功力又升级

    复合索引 在数据库操作期间,复合索引比单值索引所需要的开销更小(对于相同的多个列建索引),当表的行数远大于索引列的数目时可以使用复合索引。...哪些情况不需要建立索引 表记录太少 经常增删改的表(因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件) where 条件里用不到的字段不创建索引 数据重复且分布平均的表字段,因此应该只为最经常查询和最经常排序的数据列建立索引...SIMPLE 简单的select查询,查询中不包含子查询或者UNION ? PRIMARY 查询中若包含任何复杂的子部分,最外层查询则被标记为Primary ?...【row】 rows列显示MySQL认为它执行查询时必须检查的行数(越少越好) ? 10.【Extra】 包含不适合在其他列中显示但十分重要的额外信息。...尽量使用覆盖索引(只访问索引的查询(索引列和查询列一致)),减少(select *) ? MySQL在使用不等于(!= 或 )的时候无法使用索引,会导致全表扫描。 where age !

    57930
    领券