MySQL的执行流程

news2024/11/24 2:25:29

在聊mysql的执行流程之前,咱们要先聊聊mysql的逻辑架构。

逻辑架构

image.png
可以将上图简化为下图
image.png

连接层

客服端访问mysql服务器前,要先和mysq建立tcp连接。
经过3次握手建立连接成功后,mysql服务器对tcp传输过来的账号密码进行身份认证,权限获取。

  • 用户名或密码不对,会收到Access denied for user错误,客服端程序结束执行
  • 用户名密码认证成功,会从权限表查出账号拥有的权限与连接关联,之后的权限判断逻辑,都依赖于此时读到的权限

连接层有一个线程池,每个客服端过来和mysql服务器建立tcp连接,都需要分配一个线程专门取和这个客服端交互。使用线程池,省去了创建和销毁线程的开销。

服务层

  • SQL Interface:SQL接口

接收用户的SQL命令,并且返回用户需要查询的结果。例如select ...from就是调用SQL接口

  • Parser:解析器
    • 在解析器中对sql语句进行语法解析,语义分析。将sql语句分解成数据结构,并将这个数据结构传递给后续步骤,以后sql语句的传递和处理就是基于这个结构。如果在分解构成中遇到错误,那么就说明这个sql语句是错误的
    • sql命令传递到这个解析器的时候会被解析器验证和解析,并为其创建语法树,Mysql还会还会对sql查询进行语法上的优化,进行查询重写。
  • Optimizer:查询优化器
    • sql语句在语法解析之后,查询之前会使用查询优化器确定sql语句的执行路径,生成一个执行计划
    • 执行计划里会说明使用哪些索引进行查询,表之间的连接顺序如何,最后按照执行计划中的步骤调用存储引擎提供的方法来真正的执行查询,并将查询结果返回给用户
    • 他使用“选取-投影-连接”策略进行查询。例如
select id, name from student where gender = 'female'

select查询会先根据where进行选取,而不是将表全部查询出来再进行gender过滤。再根据id和name进行属性投影,而不是将属性全部取出来以后在进行过滤,将这两个查询条件连接起来就是最终结果。

  • Cache:查询缓存组件

MySQL 中的查询缓存,不是缓存查询计划,而是查询对应的结果。这就意味着查询匹配的鲁棒性大大降 低,只有相同的查询操作才会命中查询缓存。两个查询请求在任何字符上的不同(例如:空格、注释、 大小写),都会导致缓存不会命中。因此 MySQL 的查询缓存命中率不高。
同时,如果查询请求中包含某些系统函数、用户自定义变量和函数、一些系统表,如 mysql 、 information_schema、 performance_schema 数据库中的表,那这个请求就不会被缓存。以某些系统函数 举例,可能同样的函数的两次调用会产生不一样的结果,比如函数NOW,每次调用都会产生最新的当前 时间,如果在一个查询请求中调用了这个函数,那即使查询请求的文本信息都一样,那不同时间的两次 查询也应该得到不同的结果,如果在第一次查询时就缓存了,那第二次查询的时候直接使用第一次查询 的结果就是错误的!
此外,既然是缓存,那就有它缓存失效的时候。MySQL的缓存系统会监测涉及到的每张表,只要该表的 结构或者数据被修改,如对该表使用了INSERT、 UPDATE、DELETE、TRUNCATE TABLE、ALTER TABLE、DROP TABLE或 DROP DATABASE语句,那使用该表的所有高速缓存查询都将变为无效并从高 速缓存中删除!对于更新压力大的数据库来说,查询缓存的命中率会非常低。

引擎层

插件式存储引擎,真正负责mysql中数据的存储和提取,维护底层数据执行操作,服务器通过api与存储引擎进行通信。不同存储引擎功能也不同,根据需求而定。

存储层

所有的数据,数据库/表,表中每一行内容,索引,都会存在文件系统上。并完成与存储引擎的交互。

sql执行流程

  1. 查询缓存:Server 如果在查询缓存中发现了这条 SQL 语句,就会直接将结果返回给客户端;如果没 有,就进入到解析器阶段。
  2. 解析器 :在解析器中对 SQL 语句进行语法分析、语义分析。
    1. 分析器先做“ 词法分析 ”。你输入的是由多个字符串和空格组成的一条 SQL 语句,MySQL 需要识别出里面 的字符串分别是什么,代表什么。 MySQL 从你输的"select"这个关键字识别出来,这是一个查询语 句。它也要把字符串“T”识别成“表名 T”,把字符串“ID”识别成“列 ID”。
    2. 接着,要做“ 语法分析 ”。根据词法分析的结果,语法分析器(比如:Bison)会根据语法规则,判断你输 入的这个 SQL 语句是否 满足 MySQL 语法 。
    3. 如果sql语句正确,则会生成一个语法树:

image.png

  1. 优化器: 在优化器中会确定 SQL 语句的执行路径,比如是根据全表检索 ,还是根据索引检索等

例如:执行两个表的join

select * from test1 join test2 using(ID)
where test1.name='zhangwei' and test2.name='mysql高级课程';

方案1:可以先从表 test1 里面取出 name='zhangwei’的记录的 ID 值,再根据 ID 值关联到表 test2,再判 断 test2 里面 name的值是否等于 ‘mysql高级课程’。
方案2:可以先从表 test2 里面取出 name=‘mysql高级课程’ 的记录的 ID 值,再根据 ID 值关联到 test1, 再判断 test1 里面 name的值是否等于 zhangwei。
这两种执行方法的逻辑结果是一样的,但是执行的效率会有不同,而优化器的作用就是决定选择使用哪一个方案。优化器阶段完成后,这个语句的执行方案就确定下来了,然后进入执行器阶段

  1. 执行器

在执行之前需要判断该用户是否 具备权限 。如果没有,就会返回权限错误。如果具备权限,就执行 SQL 查询并返回结果。在 MySQL8.0 以下的版本,如果设置了查询缓存,这时会将查询结果进行缓存

select * from test where id = 1;

调用 InnoDB 引擎接口取这个表的第一行,判断 ID 值是不是1,如果不是则跳过,如果是则将这行存在结果集中; 调用引擎接口取“下一行",重复相同的判断逻辑,直到取到这个表的最后一行。
执行器将上述遍历过程中所有满足条件的行组成的记录集作为结果集返回给客户端。

SQL语句在mysql中的流程是:sql语句->查询缓存->解析器->优化器->执行器

image.png
image.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1043485.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

接口测试之文件下载

在工作中对于下载接口,经常会有这样的疑问:这类接口一般功能比较稳定,但是又比较重要,需要占用回归测试时间,有没有可替代的方式? 答案肯定是有的,可以从接口测试/UI自动化测试介入,…

UE5 虚幻引擎 使用编辑器工具进行资产批处理操作 让你的工作效率指数级增长!!!

目录 0 引言1 编辑器工具蓝图1.1 介绍1.2 案例:批量设置静态网格体资产的LOD1.3 进阶用法 2 编辑器工具控件2.1 介绍2.2 案例:随机给场景中Actor添加Yaw旋转值 0 引言 官方教程视频 参考文章 参考视频 UE5提供了两种 编辑器工具 :编辑器工具…

Dubbo学习(二)——dubbo环境搭建

文章目录 dubbo核心简介SpringCloud与Dubbo的区别Dubbo的架构说明dubbo和Feign远程调用的差异共同点:区别: 基于 Spring Boot 开发微服务应用项目介绍1. 启动注册中心2. 新建一个spring boot项目3. 添加 Maven 依赖4. 定义服务接口5. 定义服务端的实现实…

操作系统 --- 进程的描述与控制

(一 )前趋图和程序的执行 前趋图 前趋图 :有向无循环图 ,用于描述 进程之间执行的先后顺序 结点表示进程或程序段,有向边表示前趋关系 前驱图中是不允许有循环的,否则必然会产生无法实现的前驱关系。 (二…

浙大公共管理硕士(MPA)提前批面试的题库里到底有哪些内容?

像研究生招生这样严肃的工作,所有的环节和程序都得有章可循!浙大公共管理硕士(MPA)项目提前批面试即将在10月14日举行,已经通过材料审核的考生肯定很想知道面试中会遇到什么样的题目,专注浙大的杭州达立易考…

卤制品配送经营商城小程序的用处是什么

卤制品也是食品领域重要的分支,尤其对年轻人来说,只要干净卫生好吃价格合理,那复购率宣传性自是不用说,而随着互联网发展,传统线下门店也须要通过线上破解难题或进一步扩大生意。 而商城小程序无疑是商家通过线上私域…

Redis各数据类型特定的命令和用法 1.0版本

目录 一、Sring数据类型1.1 概述1.2 set/get/append/strlen命令1.3 incr/decr/incrby/decrby 命令1.4 getset命令1.5 setex命令1.6 setnx命令1.7 mset/mget/msetnx命令 二、List数据类型2.1 概述2.2 lpush/lpushx/lrange命令2.3 lpop/llen命令2.4 lrem/lset/lindex/ltrim命令2.…

信息安全:网络安全审计技术原理与应用.

信息安全:网络安全审计技术原理与应用. 网络安全审计是指对网络信息系统的安全相关活动信息进行获取、记录、存储、分析和利用的工作。网络安全审计的作用在千建立“事后“安全保障措施,保存网络安全事件及行为信息,为网络安全事件分析提供线…

SpringBoot之视图解析

文章目录 前言一、视图解析1.视图解析原理流程 二、模板引擎——Thymeleaf基本语法表达式字面量文本操作数学运算布尔运算比较运算条件运算特殊操作设置属性值-th:attr迭代条件运算属性优先级 提取公共页面th:insertth:replace区别 总结 前言 SpringBoot默认不支持 JSP&#x…

UE学习记录07----C++中使用事件委托

1.c定义多播委托,示例代码: #include "Delegates/Delegate.h"DECLARE_DYNAMIC_MULTICAST_DELEGATE_OneParam(FMyDelegate, UObject*, SelectAgent);/****/ UCLASS(Blueprintable, DisplayName "VM_PlaceEntity") class PR_PLACEE…

“益路同行”栏目人物专访第0001期—笨爸爸工房创始人张旭健先生

中国善网在第十届慈展会上特别推出了《益路同行》采访栏目,《益路同行》栏目旨在寻觅公益之路上同行者的故事,挖掘公益更深层次的内涵,探索新时代公益发展道路。希望公益企业、人物、故事被更多人看到,并呼吁更多人为公益做出自己…

san.js源码解读之工具(util)篇——splitStr2Obj函数

一、 源码解析 /*** 将字符串逗号切分返回对象** param {string} source 源字符串* return {Object}*/ function splitStr2Obj(source) {var result {};each( // 2source.split(,), // 1function (key) { // 3result[key] key;});return result; }把字符串通过 split 函数以…

力扣刷题-链表-链表相交

02.07. 链表相交 给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null 。 图示两个链表在节点 c1 开始相交: 题目数据 保证 整个链式结构中不存在环。 注意,函数返…

C语言动态内存管理malloc、calloc、realloc、free函数的讲解

一.为什么存在动态内存管理: 我们知道,在此之前向内存申请空间的方式有以下两种:(变量和数组) 但这两种方法有几个缺陷: ①:空间开辟大小是固定的; ②:数组在声明的时候&…

redis缓存穿透问题

缓存穿透是指客户端请求的数据在缓存中和数据库中都不存在,这样缓存永远不会生效,这些请求都会打到数据库 常见的解决办法: 缓存空对象:第一次请求发现redis和数据库中都不存在时,,可以设置请求数据为key,null为值,放置在缓存中. 但是会有一个问题,就是如果此类请求过多,会导…

渗透中Windows利用Certutil进行文件下载

渗透中Windows利用Certutil进行文件下载 1.概述2.利用Certutil进行文件下载 1.概述 certutil.exe 是一个合法Windows文件,用于管理Windows证书的程序。此合法Windows服务现已被广泛滥用于恶意用途 渗透中主要利用其下载、编码、解码、替代数据流等功能 可以在命令…

全流程HEC-RAS 1D/2D水动力与水环境模拟技术

查看原文>>>全流程HEC-RAS 1D/2D水动力与水环境模拟技术案例实践及拓展应用 目录 专题一、水动力模型基础 专题二、恒定流模型(1D/2D) 专题三、一维非恒定流 专题四、二维非恒定流模型(一) 专题五、二维非恒定流模型(二&#…

JSON.stringify格式化数据美化显示效果(不呆板地一行显示)

一.JSON.stringify 语法: JSON.stringify(value[, replacer[,space]])第二个参数replacer: 过滤属性或者处理值第三个参数space: 美化输出格式 第一个参数: 对象object等 第二个参数replacer: 如果该参数是一个函数: 则在序列化的过程中,被序列化的值的每个属性都会经过该函…

leetcode算法题-移动零Java

这道题的解法,我们可以新建一个等长的数组,初始化后数组中的元素都为零,我们只需要遍历一遍原来的数组,将不为0的数据转移到新数组即可,下面是代码实现: public static void main(String[] args) {System.out.println("移动零:" Arrays.toString(moveZero(new int[…

SVN_SERVER的搭建

一、目前svnserver仅支持windows下安装,所以前提需要一台windows服务器或者windows主机 1. 下载最新版本的包 当前最新版visualsvn server最新版5.3.0 visualsvn server下载地址Downloads | VisualSVN 当前tortoiseSVn最新版1.14.5 tortoise SVN下载地址 h…