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

TYPE(3)—mysql执行计划(四十九)

Subquery:子查询,不相关查询,没有转semi-join,并且mysql优化器选择了物化表查询,因为物化,只执行一次。...Select type&partitions (2)—mysql执行计划(四十八) TYPE 前面我们说过了mysql执行sql语句会采用什么方法,比如const,ref,ref_or_null,range...System 当表里只有一条记录,并且这里只有统计数据是精确的,才可以用到这个方法,注意innoDB之前说过都是估算,所以这里必须是myISAM或者memory mysql> CREATE TABLE...------------------------+1 row in set, 1 warning (0.01 sec) unique_subquery eq_ref是两表查询被驱动使用主键或者唯一索引执行计划查询数据库...-----+---------+------+------+----------+-------+| id | select_type | table | partitions | type | possible_keys

30230

Select type&partitions (2)—mysql执行计划(四十八)

id,table列(1)—mysql执行计划(四十七) Select type 我们都知道sql里会包含若干个select,每个select代表一个小的查询语句,每个select的from都可以关联若干张表...,每张表对应执行计划输出一条数据,对于同一个select下面,id是相同的。...Mysql又为每个select定义了type,取名为select type,这样就知道每个select扮演什么样的角色。...SUBQUERY 如果子查询不能满足semi-join的查询条件,该子查询是不相关子查询,并且mysql优化器会选择物化方式执行sql,这时候子查询的select_type就是subquey mysql...DEPENDENT SUBQUERY 如果包含子查询不能转成semi-join的形式,并且该子查询是相关子查询,这时候select type 就是dependent subquery mysql> EXPLAIN

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

MySQL执行计划

执行计划 4. 执行计划包含的信息: 如上图,执行计划查出来后包含如下信息: id:select 查询的序列号,包含一组数字,表示查询中执行select 子句或表的读取顺序。...select_type:常见的值有六个,主要是用来区别查询类型,是普通查询、联合查询还是子查询等。...包含以下内容: extra 含义 using filesort 说明MySQL会对数据使用一个外部的索引排序,而不是用表内的索引顺序进行读取,这种文件内排序是很费时的。...col2_col3,执行select col1 from t1 where col1 = 'a' order by col3,我们建的复合索引是三个列,而这条sql中只使用了两个,col2没了,看它的执行计划就会发现...using temporary MySQL在对查询结果排序时新建了一个临时表处理数据,常见于order by和group by,这种情况性能更差。

1K20

MySQL执行计划解读

EXPLAIN EXTENDED SELECT …… 将执行计划“反编译”成SELECT语句,运行SHOW WARNINGS 可得到被MySQL优化器优化后的查询语句 2....id如果相同,可以认为是一组,从上往下顺序执行;在所有组中,id值越大,优先级越高,越先执行 select_type  表示查询中每个select子句的类型(简单 OR复杂) ?...UNION之后,则被标记为UNION;若UNION包含在  FROM子句的子查询中,外层SELECT将被标记为:DERIVED f.从UNION表获取结果的SELECT被标记为:UNION RESULT type...MySQL执行计划的局限 •EXPLAIN不会告诉你关于触发器、存储过程的信息或用户自定义函数对查询的影响情况 •EXPLAIN不考虑各种Cache •EXPLAIN不能显示MySQL在执行查询时所作的优化工作...•部分统计信息是估算的,并非精确值 •EXPALIN只能解释SELECT操作,其他操作要重写为SELECT后查看执行计划

1.4K10

MySQL执行计划详解

MySQL执行计划详解 在使用MySQL进行数据库开发和运维过程中,我们通常需要对执行计划进行优化。 在系统设计和架构中,数据库是必不可少的一环。而优化数据库查询效率也是非常重要的一环。...MySQL是一个流行的关系型数据库管理系统。本文将介绍MySQL中的执行计划,以及如何使用执行计划来优化查询效率。 什么是执行计划执行计划MySQL查询优化器生成的一组指令,用于执行SQL语句。...在执行SQL语句时,MySQL会对SQL进行解析、优化、执行三个步骤。在优化阶段,MySQL查询优化器会生成一个执行计划,该计划被称为查询计划或执行计划。...使用MySQL Workbench MySQL Workbench是MySQL官方提供的一款可视化工具,我们可以通过它查看执行计划。...在执行计划中,我们可以看到MySQL是如何使用索引的。如果MySQL执行计划中没有使用索引,那么就需要考虑为查询添加索引了。 2.

58510

MySQL执行计划(explain)分析

MySQL执行计划(explain)分析 EXPLAIN支持对SELECT、UPDATE、INSERT、REPLACE、DELETE分析 执行计划能知道: SQL如何使用索引 联接查询的执行顺序 查询扫描的数据行数...查询union产生的结果集 或由ID为N的查询产生的结果 用途:查看数据来源 PARTITIONS列 对于分区表,显示查询的分区ID 对于非分区表,显示为NULL 用途:用于检查出低效率的跨分区扫描 TYPE...通过索引统计信息,估算的所需读取的行数 ROWS值的大小是个统计抽样结果,并不十分准确 FILTERED列 表示返回结果的行数占需读取行数的百分比 FILTERED列的值越大越好 依赖于统计信息 - 执行计划的限制...`customer_id` 捕获有问题的SQL-慢查日志 启动MySQL慢查日志 set global show_query_log_file = /sql_log/show_log.log set...参考 高性能可扩展MySQL数据库设计及架构优化 电商项目,sqlercn,https://coding.imooc.com/class/79.html

92940

mysql索引及执行计划

什么是索引 类似于一本书的目录,加速查询,会影响到锁的应用 种类 BTREE :在mysql应用99.9% innodb 做范围查询 rtree : mongodb FULLTEXT :对于大字段...BTREE查找算法演变 B-TREE 普通BTREE B+TREE 叶子节点双向指针 B++TREE 枝节点的双向指针 mysql中如何使用BTREE b树分三层 聚簇索引构建过程 leaf 叶子 存储数据行时就是有序的...的范围+指针 构建枝节点 可以优化以id列作为条件作为查询 group by , order by 都可以覆盖到 一个b树最少要有两层结构,根和叶子构成 b树 以数据页加载数据 每个数据页都是一个范围 mysql...工具 desc sql语句 explain sql语句 语句不会执行 ,只会把将来的执行计划打印出来 可以加 format=tree看每一步执行过程或者=json explain sql语句 说明 id...代表执行的顺序 值越大优先执行 从上至下 从大到小 type 代表 使用索引类型 ALL 代表没有使用索引 index 全索引扫描需要把索引全部扫描一遍才能拿到数据 会有以下情况会走这种类型

1.3K31

执行计划--mysql详解(七)

Mysql优化器-mysql详解(六) Mysql在计算成本之后生成执行计划,用explain来查看,会返回很多列。 Table:查询的表名称,查询几张表显示几行。...Select type:主要 Simple:单表或者连接查询。 Primary,union:有union语句存在的时候。 Subquery:子查询的时候。 Derived:派生查询的时候。...Type:第一个是system,当表里只有一条数据,并且是精确计算的时候(myISAM,memory),后面就是我们前面说过的const,ref,ref_null,range,index,all。...Possible key:就是我们前面说的mysql优化器在选择执行计划之前,会先把所有可能用到的索引全部计算一下成本。 Key:真实用到的索引。...还可以在执行完之后,执行show warnings会看到mysql优化器优化后的sql语句。

63730

MySQL中的执行计划

详细对MySQL执行计划每个字段的解释 1.概述 ​ 一条查询语句在经过MySQL查询优化器的各种基于成本和规则的优化会后生成一个所谓的执行计划,这个执行计划展示了接下来具体执行查询的方式...子句中有针对该表的搜索条件时,在Extra列中会提示上述额外信息 Using join buffer (Block Nested Loop):在连接查询执行过程中,当被驱动表不能有效的利用索引加快访问速度,MySQL...,表示压根儿不打算从表中读出任何记录,将会提示该额外信息 Using filesort:有一些情况下对结果集中的记录进行排序是可以使用到索引的 Using temporary:在许多查询的执行过程中,MySQL...Json格式的执行计划 上述的EXPLAIN语句输出中缺少了衡量执行计划好坏的重要执行成本属性,通过使用JSON可以查询到执行计划所花费的成本 在EXPLAIN单词和真正的查询语句中间加上FORMAT=...参考 《MySQL是怎么样运行的》

83320

MYSQL explain执行计划解读

Explain 查看SQL语句的执行计划:分析SQL执行计划,优化SQL及索引策略,run faster....---- explain结果各列含义: 一、id :select查询的序列号 二、select_type:select查询的类型,主要是区别 普通查询和联合查询、子查询之类的复杂查询。....DERIVED(衍生): 在FROM列表中包含的子查询 5.UNION:UNION中的第二个或后面的SELECT语句 6.UNION RESULT: UNION结果 三、table: 查询表 四、type...这样的情况type 是index, 并且 Extra 的值是Using index. range: 使用索引范围查询, 通过索引字段范围获取表中部分数据记录....常见于主键或唯一索引扫描 const, system: 当MySQL对查询某部分进行优化,并转换为一个常量时,使用这些类型访问。如将主键置于where列表中,MySQL就能将该查询转换为一个常量。

69920

MySQL EXPLAIN执行计划详解

详细介绍了MySQL EXPLAIN执行计划的各个字段的含义以及使用方式。 调用EXPLAIN可以获取关于查询执行计划的信息,以及如何解释输出。...文章目录 1 调用EXPLAIN 2 EXPLAIN中的列 2.1 id 2.2 select_type 2.3 table 2.4 type 2.5 possible_keys 2.6 key 2.7...MySQL会在查询上设置一个标记。当执行查询时,这个标记会使其返回关于在执行计划中每一步的信息,而不是真正完全的执行该语句。 它会返回一行或多行信息,显示出执行计划中的每一部分和执行的次序。...from contacts where contact_id <1000 UNION select * from contacts where contact_id >99000 2.2 select_type...2.4 type 关联类型,或者说访问类型,该字段表明MySQL决定如何查找表中的行。 常用的访问类型如下(性能依次从最差到最优): ALL:全表扫描,从头到尾的查找所需要的行。

1.7K140

MySQL Explain查看执行计划

我们常常用到explain这个命令来查看一个这些SQL语句的执行计划,查看该SQL语句有没有使用上了索引,有没有做全表扫描,这都可以通过explain命令来查看。...(QEP:sql生成一个执行计划query Execution plan) mysql> explain select * from user; expain出来的信息有10列,分别是id、select_type...、table、type、possible_keys、key、key_len、ref、rows、Extra,下面对这些字段出现的可能进行解释: 一、 id id相同时,执行顺序由上至下 如果是子查询,id...的序号会递增,id值越大优先级越高,越先被执行 id如果相同,可以认为是一组,从上往下顺序执行;在所有组中,id值越大,优先级越高,越先执行 二、select_type SIMPLE(简单SELECT,...在执行查询时所作的优化工作 • 部分统计信息是估算的,并非精确值 • EXPALIN只能解释SELECT操作,其他操作要重写为SELECT后查看执行计划

1.9K30

MYSQL explain执行计划解读

点击上方“码农编程进阶笔记”,选择“置顶或者星标” Explain 查看SQL语句的执行计划:分析SQL执行计划,优化SQL及索引策略,run faster....---- explain结果各列含义: 一、id :select查询的序列号 二、select_type: select查询的类型,主要是区别 普通查询和联合查询、子查询之类的复杂查询。...列表中包含了子查询 DERIVED(衍生): 在FROM列表中包含的子查询 UNION:UNION中的第二个或后面的SELECT语句 UNION RESULT: UNION结果 三、table: 查询表 四、type...这样的情况type 是index, 并且 Extra 的值是Using index. range: 使用索引范围查询, 通过索引字段范围获取表中部分数据记录....常见于主键或唯一索引扫描 const, system: 当MySQL对查询某部分进行优化,并转换为一个常量时,使用这些类型访问。如将主键置于where列表中,MySQL就能将该查询转换为一个常量。

1K40
领券