当前位置: 首页 > news >正文

06|Mysql内部组件结构

在这里插入图片描述

1. 连接器

客户端要向mysql发起通信都必须先跟Server端建立通信连接,而建立连接的工作就是由连接器完成的

mysql -h host[数据库地址] -u root[用户] -p root[密码] -P 3306

连接步骤:
1、如果用户名或密码不对,你就会收到一个"Access denied for user"的错误,然后客户端程序结束执行。
2、如果用户名密码认证通过,连接器会到权限表里面查出你拥有的权限。之后,这个连接里面的权限判断逻辑,都将依赖于此时读到的权限

一个用户成功建立连接后,即使你用管理员账号对这个用户的权限做了修改,也不会影响已经存在连接的权限。修改完成后,只有再新建的连接才会使用新的权限设置

2. 查询缓存

MySQL 拿到一个查询请求后,会先到查询缓存看看,之前是不是执行过这条语句。之前执行过的语句及其结果可能会以 key-value 对的形式,被直接缓存在内存中。key 是查询的语句,value 是查询的结果。如果你的查询能够直接在这个缓存中找到 key,那么这个 value 就会被直接返回给客户端
查询缓存弊端:
查询缓存往往弊大于利。查询缓存的失效非常频繁,只要有对一个表的更新,这个表上所有的查询缓存都会被清空。因此很可能你费劲地把结果存起来,还没使用呢,就被一个更新全清空了。对于更新压力大的数据库来说,查询缓存的命中率会非常低

3. 分析器

如果没有命中查询缓存,就要开始真正执行语句了。首先,MySQL 需要知道你要做什么,因此需要对 SQL 语句做解析。
分析器先会做“词法分析”。你输入的是由多个字符串和空格组成的一条 SQL 语句,MySQL 需要识别出里面的字符串分别是什么,代表什么。
MySQL 从你输入的"select"这个关键字识别出来,这是一个查询语句。它也要把字符串“T”识别成“表名 T”,把字符串“ID”识别成“列 ID”。
做完了这些识别以后,就要做“语法分析”。根据词法分析的结果,语法分析器会根据语法规则,判断你输入的这个 SQL 语句是否满足 MySQL 语法。
如果你的语句不对,就会收到“You have an error in your SQL syntax”的错误提醒,比如下面这个语句 from 写成了 “rom”

在这里插入图片描述
SQL语句经过分析器分析之后,会生成一个这样的语法树
在这里插入图片描述

4. 优化器

优化器是在表里面有多个索引的时候,决定使用哪个索引;或者在一个语句有多表关联(join)的时候,决定各个表的连接顺序;以及一些mysql自己内部的优化机制。

5. 执行器

如果有执行权限,就打开表继续执行。打开表的时候,执行器就会根据表的引擎定义,去使用这个引擎提供的接口

http://www.lryc.cn/news/308042.html

相关文章:

  • 文件的写出操作
  • 使用gitlab搭建npm的依赖库,并在项目中使用
  • 如何让电脑待机而wifi不关的操作方法!!
  • 如何在Spring Boot应用中进行文件预览?
  • 阿里云4核16G服务器多少钱?幻兽帕鲁配置报价
  • el-autocomplete 提示文字出不来?修改支持模糊搜索提示
  • CentOS8 同步时间chrony ntpdate已无法使用
  • NFS服务器挂载失败问题
  • (Linux学习二)文件管理基础操作命令笔记
  • Docker本地部署GPT聊天机器人并实现公网远程访问
  • html2canvas + JsPDF.js 导出pdf分页时的问题
  • Linux系统Docker部署StackEdit Markdown并实现公网访问本地编辑器
  • 从Spring Boot应用上下文获取Bean定义及理解其来源
  • 如何处理网络攻击对系统造成的损害?
  • 数字IC后端设计利器 - 《Innovus的基本使用流程和命令》(附下载)
  • Blender中四种不同的几何体类型(网格、曲线、体积和实例 )
  • Vue3 学习笔记(Day5)
  • 【网络编程】实现服务器端和客户端的通讯的简单程序
  • 如何在Portainer中部署Nginx容器并制作一个本地站点结合cpolar发布至公网可访问
  • Mysql的储存引擎
  • 【查漏补缺你的Vue基础】Vue数据监听深度解析
  • 大语言模型LLM发展历程中的里程碑项目:国内外技术革新重塑自然语言处理(LLM系列02)
  • JS二进制文件转换:File、Blob、Base64、ArrayBuffer
  • 编译opencv gpu版的条件
  • List集合的Stream流式操作实现数据类型转换
  • Ubuntu 20.04.6 LTS下edge浏览器点击图标没反应
  • php基础学习之错误处理(其一)
  • Nginx 解析漏洞复现
  • JQMobile Loader Widget 遮罩层改造
  • 练习 2 Web [ACTF2020 新生赛]BackupFile 1