| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 大数据 -> Mysql数据查询优化——sql执行顺序&执行计划 -> 正文阅读 |
|
[大数据]Mysql数据查询优化——sql执行顺序&执行计划 |
目录 sql语句的执行顺序Mysql的执行流程图如下 图片来自网络 连接器 连接器就是起到连接的作用,主要职责有 1、验证请求用户的账户和密码是否正确。 2、用于客户端的通信。Mysql的TCP协议是一个半双工通信模式因此在某一固定时刻只能由客户端向服务器请求或者服务器向客户端发送数据,而不能同时进行。
3、如果账号密码验证通过,会在mysql自带的权限表中验证当前用户权限。mysql库中有4个控制权限的表,分别为user表,db表,tables_priv表,columns_priv表。
验证过程如下:
权限设置请参考?Mysql权限设置_熟透的蜗牛的博客-CSDN博客 缓存mysql的缓存主要的作用是为了提升查询的效率,缓存以key和value的哈希表形式存储,key是具体的sql语句,value是结果的集合。如果无法命中缓存,就继续走到分析器,如果命中缓存就直接返回给客户端 。不过需要注意的是在mysql的8.0版本以后,缓存被官方删除掉了。之所以删除掉,是因为查询缓存的失效非常频繁,如果在一个写多读少的环境中,缓存会频繁的新增和失效。 需要注意 :缓存和哈希自适性索引的区别,自适性哈希是通过哈希表实现的,它是数据库自身创建的不能人为的创建和删除。通过一下sql可以查看。
? ?分析器分析器的主要作用是将客户端发过来的sql语句进行分析,这将包括预处理与解析过程,在这个阶段会解析sql语句的语义,并进行关键词(select、update、delete、where、order by、group by等等)和非关键词进行提取、解析,并组成一个解析树。另外在此过程还会对sql语法进行分析,除此之外还会校验表是否存在,表中的字段值是否存在。下面是一个解析树
?优化器能够进入到优化器阶段表示sql是符合mysql的标准语义规则的并且可以执行的,此阶段主要是进行sql语句的优化,会根据执行计划进行最优的选择,匹配合适的索引,选择最佳的执行方案。如MRR(Multi-Range Read 多范围读取)优化,ICP(Index Condition Pushdown 索引下推)优化,是否选择使用索引,选择使用主键索引还是其他索引等。 执行器在执行器的阶段,此时会调用存储引擎的API,API会调用存储引擎。下面罗列几个存储引擎。
存储引擎是基于表的,而不是数据库。使用下面sql可以查看mysql支持的存储引擎
? Sql执行顺序实际上sql语句并不是按照我们写的sql的顺序从左到右依次执行的,它是按照如下顺序执行的。
实际上这个过程也并不是绝对这样的,中间mysql会有部分的优化以达到最佳的优化效果,比如在select筛选出找到的数据集。 执行计划下面所有的sql语句是在Mysql?8.0.27版本上执行的。两张表,表结构为
explain执行如下sql
?执行计划结果如下 字段说明 id:id列的编号是 select 的序列号,有几个 select 就有几个id,并且id的顺序是按 select 出现的顺序增长的。id列越大执行优先级越高,id相同则从上往下执行,id为NULL最后执行。 select: 查询类型 (1) SIMPLE(简单SELECT,不使用UNION或子查询等)。 (2) PRIMARY(子查询中最外层查询,查询中若包含任何复杂的子部分,最外层的select被标记为PRIMARY)。 (3) UNION(UNION中的第二个或后面的SELECT语句)。 (4) DEPENDENT UNION(UNION中的第二个或后面的SELECT语句,取决于外面的查询)。 (5) UNION RESULT(UNION的结果,union语句中第二个select开始后面所有select)。 (6) SUBQUERY(子查询中的第一个SELECT,结果不依赖于外部查询)。 (7) DEPENDENT SUBQUERY(子查询中的第一个SELECT,依赖于外部查询)。 (8) DERIVED(派生表的SELECT, FROM子句的子查询)。 (9) UNCACHEABLE SUBQUERY(一个子查询的结果不能被缓存,必须重新评估外链接的第一行)。 派生查询例子
? ?其中table中的3指向的是id列的值。 table:explain 的一行正在访问哪个表。当 from 子句中有子查询时,table列是?<derivenN>?格式,表示当前查询依赖 id=N 的查询,于是先执行 id=N 的查询。当有 union 时,UNION RESULT 的 table 列的值为<union1,2>,1和2表示参与 union 的 select 行id。 partitions:查询是基于分区表的话,会显示查询将访问的分区,mysql5.6版本之后才有。 type:?这一列表示关联类型或访问类型,即MySQL决定如何查找表中的行,查找数据行记录的大概范围。 依次从最优到最差分别为:system > const > eq_ref > ref > range > index > ALL 一般来说,得保证查询达到range级别,最好达到ref。 (1)?const,?system:mysql能对查询的某部分进行优化并将其转化成一个常量。用于 primary key 或 唯一索引的所有列与常数比较时,所以表最多有一个匹配行,读取1次,速度比较快。system是 const的特例,表里只有一条元组匹配时为system。
(2) eq_ref:使用的索引是唯一索引,对于每个索引键值,表中只有一条记录匹配,简单来说,就是多表连接中使用primary key或者 unique key作为关联条件。
?(3) ref: 与eq_ref 类似,只是不使用唯一索引,而是使用普通索引或者唯一性索引的部分前缀,索引要和某个值相比较,可能会找到多个符合条件的行。
? ?其中salary字段上有普通索引。 (4) range :?范围扫描通常出现在 in()、?between 、>、<、 >= 、<=等操作中。使用一个索引来检索给定范围的行。
? ?(5) index? : 只遍历索引树就能拿到结果,一般是扫描某个二级索引,这种扫描不会从索引树根节点开始快速查找,而是直接 对二级索引的叶子节点遍历和扫描,速度还是比较慢的,这种查询一般会使用覆盖索引,二级索引一般比较小,所以这 种通常比ALL快。 首先对上面的表创建索引
?(6)All:?即全表扫描,扫描你的聚集索引的所有叶子节点。通常情况下这需要增加索引来进行优化了。
(7)null :?mysql能够在优化阶段分解查询语句,在执行阶段用不着再访问表或索引。
? possible_keys:可能用到的索引。 key: 实际用到的索引,实际情况中有可能possible_keys有值,而实际执行时候key没有值,这种情况下可能是mysql优化器觉得全表扫描比使用索引查询效率要高,而没有使用索引。如果强制mysql使用索引,则可以使用force index(索引名称)来实现。
?key_len:?这一列显示了mysql在索引里使用的字节数,通过这个值可以算出具体使用了索引中的哪些列。 字符串,char(n)和varchar(n),5.0.3以后版本中,n均代表字符数,而不是字节数,如果是utf-8,一个数字或字母占1个字节,一 个汉字占3个字节。 如果字段允许为 NULL,需要1字节记录是否为 NULL。索引最大长度是768字节,当字符串过长时,mysql会做一个类似左前缀索引的处理,将前半部分的字符提取出来做索引。
? ?name为varchar(20) 允许空值(1个字节)? ?20*3+2+1=63 age 为int? 允许空值 4+1=5 position为varchar(50)? 50*3+2+1=153 则 63+5+153=221 ref:?这一列显示了在key列记录的索引中,表查找值所用到的列或常量,常见的有:const(常量),字段名,null。 rows: 预估数据行数,并不一定等于查询的返回结果。 filtered:符合某条件的记录数百分比。 Extra: Using where——表示MySQL将对存储引擎层提取的结果进行过滤,过滤条件字段无索引, Using where本身其实和是否使用索引无关。 Using index——表示使用覆盖索引,查询的字段在覆盖索引中就可以获取到。 Using index condition——在5.6版本后加入的新特性(Index Condition Pushdown)后面具体说明。 Using filesort——表示没有使用索引的排序。 参考 : https://www.cnblogs.com/wyq178/p/11576065.html https://blog.csdn.net/admin522043032/article/details/121037081 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/16 21:59:40- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |