ToB企服应用市场:ToB评测及商务社交产业平台

标题: MYSQL执行过程和次序详解 [打印本页]

作者: 九天猎人    时间: 2024-8-23 14:08
标题: MYSQL执行过程和次序详解
一、前言

1.1、说明

就MySQL在执行过程、sql执行次序,以及一些干系关键字的留意点方面的学习分享内容。
在参考文章的基础上,会增加自己的明白、看法,盼望本文章能够在您的学习中提供资助。
如有错误的地方,欢迎指出纠错,互相学习,共同进步。
1.2、参考文章

非常感谢以下文章提供的资助
   https://www.cnblogs.com/wyq178/p/11576065.html
  https://juejin.cn/post/7002604517913001997
  https://blog.csdn.net/qq_48157004/article/details/128590851
  https://cloud.tencent.com/developer/article/1882003
  https://cloud.tencent.com/developer/article/1115019
  二、MySQL的执行过程

2.1、MySQL数据库架构的两个主要层次

2.1.1、Server层


2.1.2、存储引擎层


2.2、MySQL数据库架构图

架构图(具体详情分析可见2.3部分):

对存储引擎描述比力具体的一张架构图(可用于参考,本文章的侧重点不在存储引擎,差别的存储引擎内部实现差别)

比力官方的一张架构图

2.3、 各执行过程详情说明

2.3.1 连接器

1、建立和维护连接
连接器负责与客户端的通讯,其使用的是半双工模式(一种通讯方式,此中通讯双方可以瓜代地发送和接收数据,但不能同时举行发送和接收)。首先是与访问的客户端建立TCP连接,服务器有专门的TCP连接池,采用长连接模式复用TCP连接,颠末三次握手建立连接乐成后,之后会对TCP传输过来的账号暗码做身份认证、权限获取。在服务器内部,每个client连接都有自己的线程,即TCP连接都会分配给一个线程去执行后续的流程。这些线程轮流运行在某一个CPU内核(多核CPU)或者CPU中,缓存了线程,因此不须要为每个client连接单独创建和销毁线程 。
2、认证和权限获取
完成与访问客户端的TCP连接后,会对TCP传递过来的账号暗码举行身份认证,假如账户和暗码错误,会报错Access denied for user 'root'@'localhost' (using password: YES)。
假如用户的账户和暗码验证通过,会在MySQL自带的权限表中查询当前用户的权限(管理员可以通过GRANT和REVOKE语句来修改用户的权限),MySQL中存在4个控制权限的表,分别为user表,db表,tables_priv表,columns_priv表:

验证授权过程(MySQL会在用户举行操作时,动态地检查其权限信息,以决定是否答应该操作)如下所示:

而且MySQL支持多种身份认证方式,包括基于暗码的认证、SSL/TLS证书认证等,此中,最常用的是基于暗码的认证方式。
2.3.2 缓存

缓存主要是针对MySQL的查询语句举行的,假如是查询语句,MySQL服务器会将查询字符串作为key,查询结果作为value缓存到内存中。颠末连接器,此时MySQL服务器已经得到到了SQL字符串,假如是查询语句,服务器会使用该查询字符串作为key,去缓存中获取,假如命中缓存,直接返回结果(返回前须要做权限的验证),未命中则执行反面的逻辑。而且,在匹配的缓存的过程中,查询字符串须要完全与key匹配才算命中(即空格、解释、巨细写、某些体系函数)。当所取的数据的基表发生任何数据厘革后,MySQL服务器会主动使对应的缓存失效。在读写比例非常高的应用体系中, 缓存对性能的进步是非常明显的。当然它对内存的消耗也是非常大的。从MySQL 5.6的版本中已经默认关闭,5.7.20开始,不推荐使用查询缓存,并在MySQL 8.0中删除。
2.3.3 分析器

因为客户端发送过来的只是一段文本字符串,因此MySQL服务器还须要对该文本字符串举行解析,这个解析过程就是在分析器中完成的。分析器对客户端发过来的SQL语句举行分析,包括预处理与解析过程,在这个阶段会解析SQL语句的语义,并举行关键词和非关键词举行提取、解析,并创建一个内部数据结果(解析树)。具体的关键词包括不限定于以下:select/update/delete/or/in/where/group by/having/count/limit等。假如分析到语法错误,会直接给客户端抛出异常:ERROR:You have an error in your SQL syntax.。除了提取关键词外,还会对此中的表举行校验,假如不存在该表,同样也会报错:unknown column in field list.。通过了分析器,那么就说明客户端发送过来的文本字符串是符合SQL标准语义规则,之后MySQL服务器就要开始执行SQL语句了。
2.3.4 优化器

优化器不仅会天生SQL执行的计划,还会资助优化SQL语句。如外连接转换为内连接、表达式简化、子查询转为连接、连接次序、索引选择等一堆东西,优化的结果就是执行计划。MySQL管帐算各个执行方法的最佳时间,最终确定一条执行的SQL交给末了的执行器。
2.3.5 执行器

开始执行SQL的时候,要先判定一下对这个表有没有相应的权限,假如没有,就会返回权限错误。假如权限校验通过后,会调用存储引擎的API,API会调用存储引擎(存储引擎API只是抽象接口,下面另有个存储引擎层,具体实现还是要看表选择的存储引擎),主要有以下存储的引擎(常用的还是myisam和innodb):
存储引擎myisaminnodbmemoryarchive存储限定256TB64TB有无事务/支持//索引支持支持支持/锁的粒度表锁行锁表锁行锁数据压缩支持//支持外键/支持// 存储引擎,之前又叫表处理器,负责对具体的数据文件举行操作,对SQL的语义比如select或者update举行分析,执行具体的操作。在执行完以后会将具体的操作记录到binlog中,须要留意的一点是:select不会记录到binlog中,只有update/delete/insert才会记录到binlog中。而update会采用两阶段提交的方式,记录都redolog中。
关于binlog和redolog两个日志的说明:
binlog:

redolog:

三、SQL执行次序说明

SQL并不是按照我们的誊写次序来从前去后、左往右依次执行的,它是按照固定的次序解析的,主要的作用就是从上一个阶段的执行返回结果来提供给下一阶段使用,SQL在执行的过程中会有差别的暂时中心表,一样平常是按照如下次序:

在MySQL中,查询语句中子查询的执行次序可以根据具体情况而有所差别,但一样平常来说,以下是一个常见的执行次序:


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4