热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MySql性能优化(三)执行计划详解

执行计划执行计划执行计划概述idselect_typetabletypepossible_keyskeykey_lenrefrowsextra官网地址在具体的应用当中,




执行计划

执行计划


  • 执行计划
    • 概述
      • id
      • select_type
      • table
      • type
      • possible_keys
      • key
      • key_len
      • ref
      • rows
      • extra




官网地址
在具体的应用当中,我们排查sql有没有走索引,性能如何,需要查看Sql语句具体的执行过程,以方便我们调整sql来加快sql的执行效率。
可以使用 EXPLAIN + SQL 的语句来模拟优化器执行sql语句,从而知道mysql如何处理sql语句。


概述

执行计划当中包含的信息
在这里插入图片描述


id

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

1.id 相同
如果id相同,那么执行顺序从上到下

2.id 不同
如果id不同。如果是子查询,id顺序会递增,id大的先执行

2.id 相同和不同的同时存在
相同的认为是同一组,从上往下顺序执行。在所有组中,id值越大,越先被执行


select_type

在这里插入图片描述

simple: 简单的查询,不包含子查询和union
primary:查询中包含任何复杂的子查询,最外层查询被标记为primary
union:若第二个查询出现在union之后,则被标记为union
dependent union:跟union类似,这里的dependent/dependent all 表示union /union all 联合而成的结果会受到外部影响
union result: 从union获取结果的select
subquery: 在select或者where列表当中包含的子查询
dependent subquery:subquery的子查询要受到外部表查询的影响
DERIVED:form子句中出现的子查询,也叫作派生类
UNCACHEABLE SUBQUERY:表示使用子查询的结果不能被缓存
uncachedable union:表示union子查询的结果不能被缓存

table

表示对应行正在访问哪一个表,表名或者别名,可能是临时表或者union合并结果集

1.如果是具体的表名,则表明从实际的物理表当中获取数据,当然也可能是表的别名
2.表名是derivedN的形式,表明使用了id为N的查询产生的衍生表
3.当有union result 的时候,表名是union n1,n2等的形式,n1,n2表示擦浴union的id

type

type显示的是访问类型,访问类型是表示我是以何种方式去访问我们的数据,最容易想到的是全表扫描,直接暴力遍历一张表去寻找需要的数据,效率十分低下,访问类型有很多,效率从好到坏分别有:
system>const>eq_ref>ref>fulltext>ref_or_null>index_merge>unique_subquery>index_subquery>range>index>ALL
一般情况下,得保证查询达到range范围及其以上

1.system:表只有一行记录(等于系统表),这是const类型的特例,平时不会出现
2.const:这个表至多一个匹配行
explain select * from table1 where table_unique_no = "1234***"
3.eq_ref使用唯一索引进行数据查找
explain select * from table1,table2 where table1.no = table2.no;
4.ref 使用非唯一索引进行数据的查找
create index idx_1 on table1(no2);
explain select * from table1,table2 where table1.no2 = table2.no2;
5.ref_or_null 对于某个字段既需要关联条件,也需要null值的情况下,查询优化器会选择这种访问方式
explain select * from table1 where no is null or no = "xxxx";
6.index_merge:在查询中需要多个索引组合使用
7.unique_subquery:利用索引关联子查询,不在扫描全表,使用的是唯一索引
explain select * from table1 where table1.no in (select distinct no from table2 ) ;
8.index_subquery:和unique_subquery 类似,不过使用的不是唯一索引
explain select * from table1 where table1.no2 in (select distinct no2 from table2 ) ;
9.range:表示利用索引查询的时候限制了范围&#xff0c;在指定范围内进行查询&#xff0c;这样避免了使用index的全索引扫描&#xff0c;适用操作符有 &#61;, <>, >, >&#61;, <, <&#61;, IS NULL, BETWEEN, LIKE, or IN()
create index idx_3 on table1(no3);
explain select * from table1 where table1.no3 between 100 and 1000;
10.index:全索引扫描&#xff0c;效率比all好&#xff0c;主要有两种情况&#xff0c;一种当前查询覆盖索引&#xff0c;即我们当前需要的数据在索引中就可以拿到&#xff0c;二是使用了索引进行排序&#xff0c;这样就避免了数据的重排序
explain select no3 form table1;
11.ALL:全表扫描&#xff0c;一般出现这种且数据量较大的时候就需要优化了
explain select * from table1

possible_keys

显示可能应用在这个表中的索引&#xff0c;一个或者多个&#xff0c;查询涉及到的字段上若存在索引&#xff0c;则该索引将被列出&#xff0c;但不一定被实际使用。


key

实际使用的索引&#xff0c;若为null&#xff0c;则没有使用索引&#xff0c;查询中若使用了覆盖索引&#xff0c;则该索引和查询的select字段重叠


key_len

表示索引中使用的字节数&#xff0c;可以通过key_len计算查询中使用的索引长度&#xff0c;在不损失精度的情况下长度越短越好


ref

显示索引哪一列被使用了&#xff0c;如果可能的话&#xff0c;是一个常数


rows

根据表的统计信息及索引的使用情况&#xff0c;大致估算出找出所需记录需要读取的行数&#xff0c;此参数很重要&#xff0c;直接反应的sql查询多少数据&#xff0c;在完成目标的情况下越少越好


extra

包含额外的信息

1.using filesort:说明mysql无法利用索引进行排序&#xff0c;只能利用排序算法进行排序&#xff0c;会消耗额外的位置
2.using temporary:建立临时表来保存中间结果&#xff0c;查询完成之后把临时表删除
3.using index:这个表示当前的查询时覆盖索引的&#xff0c;直接从索引中读取数据&#xff0c;而不用访问数据表。如果同时出现using where 表名索引被用来执行索引键值的查找&#xff0c;如果没有&#xff0c;表面索引被用来读取数据&#xff0c;而不是真的查找
4.using where:使用where进行条件过滤
5.using join buffer:使用连接缓存&#xff0c;情况没有模拟出来
6.impossible where&#xff1a;where语句的结果总是false






推荐阅读
  • Explain如何助力SQL语句的优化及其分析方法
    本文介绍了Explain如何助力SQL语句的优化以及分析方法。Explain是一个数据库SQL语句的模拟器,通过对SQL语句的模拟返回一个性能分析表,从而帮助工程师了解程序运行缓慢的原因。文章还介绍了Explain运行方法以及如何分析Explain表格中各个字段的含义。MySQL 5.5开始支持Explain功能,但仅限于select语句,而MySQL 5.7逐渐支持对update、delete和insert语句的模拟和分析。 ... [详细]
  • 电话号码的字母组合解题思路和代码示例
    本文介绍了力扣题目《电话号码的字母组合》的解题思路和代码示例。通过使用哈希表和递归求解的方法,可以将给定的电话号码转换为对应的字母组合。详细的解题思路和代码示例可以帮助读者更好地理解和实现该题目。 ... [详细]
  • 本文介绍了如何在MySQL中将零值替换为先前的非零值的方法,包括使用内联查询和更新查询。同时还提供了选择正确值的方法。 ... [详细]
  • IhaveconfiguredanactionforaremotenotificationwhenitarrivestomyiOsapp.Iwanttwodiff ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • ALTERTABLE通过更改、添加、除去列和约束,或者通过启用或禁用约束和触发器来更改表的定义。语法ALTERTABLEtable{[ALTERCOLUMNcolu ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 本文讨论了如何使用IF函数从基于有限输入列表的有限输出列表中获取输出,并提出了是否有更快/更有效的执行代码的方法。作者希望了解是否有办法缩短代码,并从自我开发的角度来看是否有更好的方法。提供的代码可以按原样工作,但作者想知道是否有更好的方法来执行这样的任务。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 本文介绍了在MySQL8.0中如何查看性能并解析SQL执行顺序。首先介绍了查询性能工具的开启方法,然后详细解析了SQL执行顺序中的每个步骤,包括from、on、join、where、group by、having、select distinct、union、order by和limit。同时还介绍了虚拟表的概念和生成过程。通过本文的解析,读者可以更好地理解MySQL8.0中的性能查看和SQL执行顺序。 ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • 十大经典排序算法动图演示+Python实现
    本文介绍了十大经典排序算法的原理、演示和Python实现。排序算法分为内部排序和外部排序,常见的内部排序算法有插入排序、希尔排序、选择排序、冒泡排序、归并排序、快速排序、堆排序、基数排序等。文章还解释了时间复杂度和稳定性的概念,并提供了相关的名词解释。 ... [详细]
  • 基于dlib的人脸68特征点提取(眨眼张嘴检测)python版本
    文章目录引言开发环境和库流程设计张嘴和闭眼的检测引言(1)利用Dlib官方训练好的模型“shape_predictor_68_face_landmarks.dat”进行68个点标定 ... [详细]
  • 本文介绍了在iOS开发中使用UITextField实现字符限制的方法,包括利用代理方法和使用BNTextField-Limit库的实现策略。通过这些方法,开发者可以方便地限制UITextField的字符个数和输入规则。 ... [详细]
author-avatar
王小志2602928087
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有