MySQL架构和工作流程

引言:MySQL执行一条sql语句期间发生了什么?

想要搞清楚这个问题,我们必须了解MySQL的体系结构工作流程

一、MySQL体系结构

在这里插入图片描述

MySQL由以下几个部分组成

一、server层

1.MySQL Connnectors连接器,MySQL的连接池组件,网络连接使用io多路复用select处理

主线程:处理连接请求(select)

子线程:对应一条连接,处理该连接的sql请求

也就是说MySQL为每一条客户端连接创建一个线程来专门处理该连接的sql请求,因此,mysql的sql处理是多线程的,所以mysql默认最大连接数为151,过多的线程会占用大量内存

2.查询缓存

对于用户发送的sql查询请求(select)会先在缓存中查找,这个缓存是以key(sql命令)-value(结果)的方式存储的,如果找到则直接返回对应的结果value,没找到则进行下一步

在mysql8.0版本弃用了查询缓存,原因是在实际统计的使用数据中,查询缓存的命中率很低

命中率低的原因是:只要一个表有更新(修改)操作,这个表的查询缓存会被清空,所以每一次的查询缓存都是在该表的最新查询缓存中查找的,而不是所有缓存。因此,表更新则清空缓存的策略是安全且必要的,但是同时使得查询缓存的命中率很低

3.解析器

查询缓存未命中或mysql8.0后的版本,对于一个sql请求,mysql的server层要做的是进行词法语法分析,检查该sql语句是否符合协议,sql语句正确后生成语法树

4.预处理器

1.检查sql语句中指定的表和字段是否存在

2.将 * 替换为表中所有的列名

5.优化器

对于经过预处理的sql语句,优化器负责生成执行计划(执行sql的具体步骤),一般来说,优化器会生成多个执行计划,并选择出一个最优的计划,交由执行器执行

二、存储引擎(mysql使用innodb)

6.执行器

执行器和存储引擎进行交互

一条sql语句的执行流程

1.连接器:建立连接、管理连接、校验用户身份

2.查询缓存(mysql 8.0版本前):sql语句命中缓存则直接返回结果,未命中则继续执行

3.解析sql:进行词法(关键字)句法(语法)分析,生成语法树

4.执行sql:

  • 预处理:检查表和字段是否存在
  • 优化:生成执行计划并选择决定最优计划
  • 执行:执行器使用存储引擎提供的api与之交互

行sql:

  • 预处理:检查表和字段是否存在
  • 优化:生成执行计划并选择决定最优计划
  • 执行:执行器使用存储引擎提供的api与之交互

推荐学习 https://xxetb.xetslk.com/s/p5Ibb

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

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

相关文章

数据结构+算法-实现一个计算器

在学习栈的数据结构的时候讲到可以用栈来实现一个计算器的功能,那么这个功能是如何实现的呢? 采用栈模拟得方式来实现一个计算器 要实现如下的功能: 字符串如何转为整数 2.处理加减法 如何处理加减法呢? 5-128 给第一个数字前面放一个号…

python ui 工作流完善功能

说明 这段代码是一个使用Tkinter编写的图形用户界面(GUI)应用程序,它用于编辑工作流。以下是代码的主要部分和功能的说明: Tooltip类:这是一个自定义类,用于创建一个工具提示窗口,当鼠标悬停在…

UEC++ 虚幻5第三人称射击游戏(二)

UEC++ 虚幻5第三人称射击游戏(二) 派生榴弹类武器 新建一个继承自Weapon的子类作为派生榴弹类武器 将Weapon类中的Fire函数添加virtual关键字变为虚函数让榴弹类继承重写 在ProjectileWeapon中重写Fire函数,新建生成投射物的模版变量 Fire函数重写逻辑 代码//生成的投射物U…

100亿条密码的文档泄露,或成为年度最大密码泄露事件

研究小组将 RockYou2024 泄露事件中包含的密码与 Cybernews 的泄露密码检查器中的数据进行了交叉比对,发现这些密码均来自此前发生的数据泄露事件。 RockYou2024密码汇编集合里包含世界各地个人使用的真实密码。研究人员认为,黑客将数量如此庞大的密码泄…

从文本到安全图像:自动提示优化防止不当内容生成

T2I生成技术已经得到了广泛关注,并见证了如GLIDE、Imagen、DALL-E 2、Stable Diffusion等大型生成模型的发展。尽管这些模型能够根据文本描述生成高质量的图像,促进了书籍插图、品牌标识设计、游戏场景创作等多种实际应用,但它们也被恶意用户…

vs2022 远程启动调试

vs2015如何远程启动程序来进行调试_vs2015远程调试-CSDN博客

05.06 - 05.18_111期_Linux_信号

signal 可以自定义进程在接收到指定信号后&#xff0c;会执行的函数 sigaction 除了可以做signal 可以做的功能&#xff0c;还可以通过sigaction这个结构体了解信号的更多具体信息 void sigcb(int sig) {std::cout << " get a sig: " << sig << …

实现浏览器语音呼起及语音录入及下载

主要分布三部分: 第一部分:开始录音 ;第二部分:停止录音;第三部分:静默监听。 一、开始录音 代码如下: document.getElementById(startRecording).onclick = async function() {if (navigator.mediaDevices && navigator.mediaDevices.getUserMedia) {try {au…

使用京东云主机搭建幻兽帕鲁游戏联机服务器全流程,0基础教程

使用京东云服务器搭建幻兽帕鲁Palworld游戏联机服务器教程&#xff0c;非常简单&#xff0c;京东云推出幻兽帕鲁镜像系统&#xff0c;镜像直接选择幻兽帕鲁镜像即可一键自动部署&#xff0c;不需要手动操作&#xff0c;真正的新手0基础部署幻兽帕鲁&#xff0c;阿腾云整理基于京…

Python学习笔记30:进阶篇(十九)pygame的使用之显示与窗口管理

前言 基础模块的知识通过这么长时间的学习已经有所了解&#xff0c;更加深入的话需要通过完成各种项目&#xff0c;在这个过程中逐渐学习&#xff0c;成长。 我们的下一步目标是完成python crash course中的外星人入侵项目&#xff0c;这是一个2D游戏项目。在这之前&#xff…

YOLOv8改进 | 注意力机制 | 结合静态和动态上下文信息的注意力机制

秋招面试专栏推荐 &#xff1a;深度学习算法工程师面试问题总结【百面算法工程师】——点击即可跳转 &#x1f4a1;&#x1f4a1;&#x1f4a1;本专栏所有程序均经过测试&#xff0c;可成功执行&#x1f4a1;&#x1f4a1;&#x1f4a1; 专栏目录 &#xff1a;《YOLOv8改进有效…

力扣双指针算法题目:双数之和,三数之和,四数之和

目录 一&#xff1a;双数之和 1.题目&#xff1a; 2.思路解析 3.代码 二&#xff1a;三数之和 1.题目 2.思路解析 3&#xff0c;代码 三&#xff1a;四数字之和 1.题目 2.思路解析 3.代码 一&#xff1a;双数之和 1.题目&#xff1a; 输入一个递增排序的数组和一…

EtherCAT主站IGH-- 9 -- IGH之eoe_request.h/c文件解析

EtherCAT主站IGH-- 9 -- IGH之eoe_request.h/c文件解析 0 预览一 该文件功能`eoe_request.c` 文件功能函数预览二 函数功能介绍1. `ec_eoe_request_init`示例用法示例详细说明三 h文件翻译四 c文件翻译该文档修改记录:总结0 预览 一 该文件功能 该文件定义了用于 EtherCAT 的…

【DOM】实现一个课程表的拖拽功能

历史小剧场 一个皇帝从不需要用个人的良好品格来证明自己的英明&#xff0c;恰恰相反&#xff0c;在历史上&#xff0c;干皇帝这行的人基本都不是什么好人&#xff0c;因为好人干不了皇帝&#xff0c;朱匀炆就是铁证。----《明朝那些事儿》 1. 前置知识 1.1 DataTransfer接口 …

怎么有逻辑的说话?

怎么有逻辑的说话&#xff0c;一节黄执中的课。 平时我们常会被说说话没有逻辑&#xff0c;那么什么叫做有逻辑呢&#xff1f; 黄执中说有明确的主张就是有逻辑。这里的主张&#xff0c;包括了有议题&#xff0c;有结论&#xff0c;有理由。 举一个正面的例子&#xff0c;比…

贵州建筑三类人员安全员2024年考试最新题库练习题

一、单选题 1.建设工程安全管理的方针是&#xff08;&#xff09;。 A.安全第一&#xff0c;预防为主&#xff0c;综合治理 B.质量第一&#xff0c;兼顾安全 C.安全至上 D.安全责任重于泰山 答案&#xff1a;A 2.安全生产管理的根本目的是&#xff08;&#xff09;。 A.…

Lunaproxy与711Proxy的对比与优劣分析

今天我们来深入对比两款在市场上备受关注的代理IP服务&#xff1a;Lunaproxy和711Proxy。接下来&#xff0c;我们将从多个角度对这两款服务进行详细分析&#xff0c;帮助大家做出明智的选择。 优势分析 711Proxy的优势 1. 性价比高&#xff1a;711Proxy提供多种灵活的套餐选…

伪元素content追加文字使用小技巧

E::before和E::after本身的作用是追加字&#xff0c;直接在文字后面追加链接 <!DOCTYPE html> <html lang"zh-cn"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-sca…

AI文本转语音,再也不用担心视频配音了.

文章目录 简介代码实现调用开通百度付费包 简介 背景 我想要将文本,转为语音,然后配上图片,这样就可以很快生成一个视频. 可以说是配音吧,我还是比较喜欢通过代码来自动化.所以今天就来实现一下,同时做一下分享和记录.目标 通过python代码,自动将文本转为配音.平台 我选择了百…

中位值平均滤波法(又称防脉冲干扰平均滤波法)

中位值平均滤波法(又称防脉冲干扰平均滤波法) 中位值平均滤波法:采一组队列去掉最大值和最小值后取平均值,相当于“中位值滤波法”+“算术平均滤波法”。连续采样N个数据,去掉一个最大值和一个最小值,然后计算N-2个数据的算术平均值。 优点:融合了“中位值滤波法”+“算…