EXPLAIN不会告诉你关于触发器、存储过程的信息或用户自定义函数对查询的影响情况。 EXPLAIN不考虑各种Cache(缓存)。 EXPLAIN不能显示MySQL在执行查询时所作的优化工作。...SUBQUERY(subquery):子查询中的第一个SELECT,结果不依赖于外部查询。...UNCACHEABLE SUBQUERY(uncacheable subquery):(一个子查询的结果不能被缓存,必须重新评估外链接的第一行) 3 table 输出结果集的表名称。...4 partitions 输出结果集的表所在的分区 5 TYPE type显示的是访问类型,是较为重要的一个指标,结果值从好到坏依次是: Null > system > const > eq_ref >...Using temporary:为了解决查询,MySQL需要创建一个临时表来容纳结果集,常见于排序和分组查询,常见 group by、order by。
转自:http://blog.chinaunix.net/uid-540802-id-3419311.html explain显示了mysql如何使用索引来处理select语句以及连接表。...将在表4.3中讨论,但这里可以看到的坏的例子是Using temporary和Using filesort,意思MYSQL根本不能使用索引,结果是检索会很慢 extra列返回的描述的意义 Distinct...这里,MYSQL需要创建一个临时表来存储结果,这通常发生在对不同的列集进行ORDER BY上,而不是GROUP BY上 Where used 使用了WHERE从句来限制哪些行将与下一张表匹配或者是返回给用户...Using temporary:为了解决查询,MySQL需要创建一个临时表来容纳结果。 Using where:WHERE 子句用于限制哪一个行匹配下一个表或发送到客户。...mysql会将多个索引合并在一起,如下例: mysql> explain select * from t_order where order_id=100 or user_id=10; ±—±----
MySQL中explain的结果字段介绍(二) 昨天说完了执行计划的前四个字段,今天说说后面几个字段吧。...我们看看explain的基本语法和输出内容: mysql ::>>explain select ; +----+-------------+-------+------+---------------+...首先我们定义一个表,这样我们分析这些关系的时候,就能更加清楚了。...此时表test_explain的存储引擎是myisam,有2条记录,我们修改存储引擎为innodb,然后删除1条记录,再来看结果: mysql:yeyztest 17:41:55>>alter table...mysql:yeyztest 18:55:38>>explain select * from test_explain t1 where t1.id in (select t2.id from test_explain
先看一个例子: mysql> explain select * from t_order; +----+-------------+---------+------+---------------+-...Using temporary:为了解决查询,MySQL需要创建一个临时表来容纳结果。 Using where:WHERE 子句用于限制哪一个行匹配下一个表或发送到客户。...Using temporary:为了解决查询,MySQL需要创建一个临时表来容纳结果。 Using where:WHERE 子句用于限制哪一个行匹配下一个表或发送到客户。...一.select_type的说明 1.UNION: 当通过union来连接多个查询结果时,第二个之后的select其select_type为UNION。...mysql会将多个索引合并在一起,如下例: mysql> explain select * from t_order where order_id=100 or user_id=10; +----+-
explain是sql优化时的重要工具 使用方法 在要分析的sql语句签名添加 explain ,例如 explain select * from user; 结果项说明 id 查询的编号 select_type...primary 含子查询或派生查询 subquery 非from子查询 derived from型子查询 union union result table 查询针对的表,可以是表名或别名、执行结果
简介 ---- MySQL 提供了一个 EXPLAIN 命令, 它可以对 SELECT 语句进行分析, 并输出 SELECT 执行的详细信息, 以供开发人员针对性优化....即子查询依赖于外层查询的结果....输出 的结果类似如下: mysql> EXPLAIN (SELECT * FROM user_info WHERE id IN (1, 2, 3)) -> UNION -> (SELECT..., 都只能匹配到后表的一行结果....MySQL 查询优化器根据统计信息, 估算 SQL 要查找到结果集需要扫描读取的数据行数. 这个值非常直观显示 SQL 的效率好坏, 原则上 rows 越少越好.
explain显示了mysql如何使用索引来处理select语句以及连接表。可以帮助选择更好的索引和写出更优化的查询语句。...使用方法,在select语句前加上explain就可以了: 先看个例子 mysql> explain select * from t_order; | id | select_type | table...SELECT UNION:UNION中的第二个或后面的SELECT语句 DEPENDENT UNION:UNION中的第二个或后面的SELECT语句,取决于外面的查询 UNION RESULT:UNION 的结果...Using temporary:为了解决查询,MySQL需要创建一个临时表来容纳结果。 Using where:WHERE 子句用于限制哪一个行匹配下一个表或发送到客户。...Using temporary:为了解决查询,MySQL需要创建一个临时表来容纳结果。 Using where:WHERE 子句用于限制哪一个行匹配下一个表或发送到客户。
MySQL 之 Explain 输出分析 背景 前面的文章写过 MySQL 的事务和锁,这篇文章我们来聊聊 MySQL 的 Explain,估计大家在工作或者面试中多多少少都会接触过这个。...Explain 可以使用在SELECT, DELETE, INSERT, REPLACE, and UPDATE 语句中,执行的结果会在每一行显示用到的每一个表的详细信息。...简单语句可能结果就只有一行,但是复杂的查询语句会有很多行数据。...Explain 的使用 在 SQL 语句前面加上 explain,如:EXPLAIN SELECT * FROM a; 举个例子 CREATE TABLE `a` ( `id` int(10) unsigned...subquery: 子查询中的第一个SELECT,取决于外部查询•derived: 派生表——该临时表是从子查询派生出来的,位于from中的子查询•uncacheable subquery: 无法缓存结果的子查询
MySQL中explain的结果字段介绍 我们在使用MySQL的时候,用的最多的情况可能就是select语句了,当我们在一个表查找数据的时候,经常会遇到查找的速度比较慢的情况,作为一名DBA,我也会经常遇见业务方写的...MySQL中,可以通过explain的语句来查看一个SQL的执行计划。...explain的语法大家可能都清楚,我们看看explain的基本语法和输出内容: mysql 19:49:29>>explain select 1; +----+-------------+------...关于id,其实就是一个SQL对应一个id,如果有子查询,那么子查询也将对应一个id值,但是这个id值稍有不同,看下面的SQL: mysql:yeyztest 23:03:52>>explain select...,正常来讲,这个表是保存在内存中的),则这个select_type就是subquery,这个我们给出例子: mysql> EXPLAIN SELECT * FROM test2 WHERE id IN
MySQL中explain中的结果字段介绍(三) 之前的文章中对于explain的数据结果中的字段已经进行了一部分介绍了,今天来说一说剩下的几个字段,为了防止忘记,先看看这个表结构: mysql...mysql:yeyztest 21:30:40>>alter table test_explain modify a_key_var varchar(100) not null default '';...,ref字段的值都是const,是因为我们使用常量a或者常量2和索引字段进行匹配,如果我们使用某个字段进行匹配,来看下面: mysql:yeyztest 22:24:42>>explain select...,大概有多少比率的记录符合age<30.如下: mysql:yeyztest 22:40:36>>explain select * from test_1 where id>=4 and age<30;...Using where 表示Mysql将对storage engine提取的结果进行过滤,过滤条件字段无索引; Using temporary 要解决查询,MySQL需要创建一个临时表来保存结果。
MySQL执行计划(explain)分析 EXPLAIN支持对SELECT、UPDATE、INSERT、REPLACE、DELETE分析 执行计划能知道: SQL如何使用索引 联接查询的执行顺序 查询扫描的数据行数...DERIVED:出现在FROM子句中的子查询 用途:查看查询方法 TABLE列: 输出数据行所在的表的名称 由ID为M,N查询union产生的结果集 或由ID为N的查询产生的结果 用途:查看数据来源...通过索引统计信息,估算的所需读取的行数 ROWS值的大小是个统计抽样结果,并不十分准确 FILTERED列 表示返回结果的行数占需读取行数的百分比 FILTERED列的值越大越好 依赖于统计信息 - 执行计划的限制...无法展示存储过程,触发器,UDF对查询的影响 无法使用EXPLAIN对存储过程进行分析 早期版本的MySQL只支持对SELECT语句进行分析 常见业务优化处理 优化评论分页查询 例子 SELECT customer_id...,使用 mysqldumpslow工具,例如: mysqldumpslow slow-mysql.log 参考 高性能可扩展MySQL数据库设计及架构优化 电商项目,sqlercn,https://coding.imooc.com
做一个积极的人 编码、改bug、提升自己 我有一个乐园,面向编程,春暖花开 文章目录 explain用法 explain结果字段的含义介绍 id select_type table type possible_keys...key key_len ref rows filtered Extra explain使用实例 总结 参考博文 拓展阅读 使用 explain 查询和分析SQl的执行记录,可以进行sql的性能优化!...explain用法 mysql> explain select * from students; +----+-------------+----------+------+--------------...Using temporary:为了解决查询,MySQL需要创建一个临时表来容纳结果。 Using where:WHERE 子句用于限制哪一个行匹配下一个表或发送到客户。...参考博文 mysql中explain用法和结果的含义 EXPLAIN 命令详解 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/121081.html原文链接:https
MySQL EXPLAIN详解:http://www.jianshu.com/p/ea3fc71fdc45 MySQL EXPLAIN命令是查询性能优化不可缺少的一部分,该文主要讲解explain...类型 说明 Using filesort MySQL有两种方式可以生成有序的结果,通过排序操作或者使用索引,当Extra中出现了Using filesort 说明MySQL使用了后者,但注意虽然叫filesort...使用explain,可以分析出需要在哪里加上索引,以及调整表的连接,以达到优化查询的目的;explain命令之后不仅可以跟select语句,也可以跟delete,insert,update,replace...我们看到explain命令的结果有很多列,通常情况下,我们最关心的指标是select_type和type。...Using temporary:表示MySQL需要使用临时表来存储结果集,常见于排序和分组查询,常见 group by ; order by。
之前是一直没有听过explain这个关键字的, 最近因为项目中总是会有慢查询的一些操作, 所以请教了旁边的同事帮忙排查下原因, 看到同事用explain来分析一些sql语句, 感觉好像发现了新大陆一样。...然后使用explain进行各种查询: ?...通过主键id去查询,其中有几个关键的指标需要关注: 首先看下 type 这列的结果,如果有类型是 ALL 时,表示预计会进行全表扫描(full table scan)。...再来看下 Extra 列的结果,如果有出现 Using temporary 或者 Using filesort 则要多加关注: Using temporary,表示需要创建临时表以满足需求,通常是因为
MySQL系列-高级-性能分析工具-EXPLAIN 1. EXPLAIN概述 1.1 官网介绍 1.2 EXPLAIN 基本语法 2....EXPLAIN概述 1.1 官网介绍 https://dev.mysql.com/doc/refman/5.7/en/explain-output.html https://dev.mysql.com...information about how MySQL executes statements: EXPLAIN语句提供了MySQL如何执行语句的信息: EXPLAIN works with...eq_ref 可用于使用=运算符比较的索引列 输入: EXPLAIN SELECT * FROM s1 INNER JOIN s2 ON s1.id = s2.id; 输出: 从执行计划的结果中可以看出...输入: EXPLAIN SELECT * FROM s1; 输出: 结果值从最好到最坏依次是: system > const > eq_ref > ref > fulltext > ref_or_null
MySQL Explain详解 简介 执行计划(query Execution plan) 语法 explain select * from table explain 中的列 expain出来的信息有...:该行是指用于与该行的派生表结果id的值 N。...例如,派生表可以来自FROM子句中的子查询 :该行指的是id 值为的行的具体化子查询的结果N 四、type 表示MySQL在表中找到所需行的方式,又称“访问类型”。...如果是这样,创造一个适当的索引并且再次用EXPLAIN检查查询 六、Key key列显示MySQL实际决定使用的键(索引) 如果没有选择索引,键是NULL。...根据表统计信息及索引选用情况,估算的找到所需的记录所需要读取的行数 十、Extra 该Extra列 EXPLAIN输出包含MySQL解决查询的额外信息。
MySQL explain explain select/update ......官方文档:https://dev.mysql.com/doc/refman/8.0/en/explain-output.html 都是越小越好,rows * filtered explain 说明 id...UNION、UNION RESULT SUBQUERY、DEPENDENT SUBQUERY 派生表 DERIVED、DEPENDENT DERIVED 物化子查询 MATERIALIZED 无法缓存结果子查询
在上一篇文章《MySQL常见加锁场景分析》中,我们聊到行锁是加在索引上的,但是复杂的 SQL 往往包含多个条件,涉及多个索引,找出 SQL 执行时使用了哪些索引对分析加锁场景至关重要。...为此,我们需要使用 explain 来获取 MySQL 执行这条 SQL 的执行计划。 什么是执行计划呢?...简单来说,就是 SQL 在数据库中执行时的表现情况,通常用于 SQL 性能分析、优化和加锁分析等场景,执行过程会在 MySQL 查询过程中由解析器,预处理器和查询优化器共同生成。...MySQL 查询过程 如果能搞清楚 MySQL 是如何优化和执行查询的,不仅对优化查询一定会有帮助,还可以通过分析使用到的索引来判断最终的加锁场景。 下图是MySQL执行一个查询的过程。...MySQL根据优化器生成的执行计划,再调用存储引擎的API来执行查询。 将结果返回给客户端。
>Select version(); 2.执行状态分析 显示哪些线程正在运行 >show processlist; 下面是完整的信息 3.show profile show profile默认的是关闭的...,但是会话级别可以开启这个功能,开启它可以让MySQL收集在执行语句的时候所使用的资源。...utm_source=tuicool&utm_medium=referral 4.分析执行计划和最左前缀原理 >explain + sql 关于分析结果需要注意索引有没有用到。...当用Explain查看SQL的执行计划时,里面有列显示了 key_len 的值,根据这个值可以判断索引的长度,在组合索引里面可以更清楚的了解到了哪部分字段使用到了索引。...小技巧,可以加 \G以按行来显示分析结果,避免因为按列显示不下的情况: 5.索引选择性与前缀索引 因为索引虽然加快了查询速度,但索引也是有代价的,另外,MySQL在运行时也要消耗资源维护索引,因此索引并不是越多越好
领取专属 10元无门槛券
手把手带您无忧上云