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

mysql架构查询执行流程(图解+描述)

目录

mysql架构查询执行流程

图解

描述 


mysql架构查询执行流程

图解

描述 

用户连接到数据库后,由连接器处理

  • 连接器负责跟客户端建立连接、获取权限、维持和管理连接

客户端发送一条查询给服务器

  • 服务器先检查查询缓存,如果命中缓存,则立即返回存储在缓存中的结果 ; 否则进入下一阶段

服务器进行SQL解析、预处理得到解析树

  • 分析器主要有两步: 词法分析和语法分析 ; 预处理器根据mysql规则检查解析树是否合法
  • 语法解析器和预处理:mysql通过关键字将sql语句进行解析,并生成一颗对应的 “解析树”

由优化器生成对应的执行计划(这个过程中任何语法等错误都可能终止查询)

  • 优化器是在表里面有多个索引的时候,决定使用哪个索引 / 在一个语句有多表关联的时候,决定各个表的连接顺序

mysql通过分析器知道了你要做什么,通过优化器知道了该怎么做,于是就进入了执行器阶段,开始执行语句

  • 开始执行的时候,要先判断一下你对这个表有没有执行查询的权限
  • 如果没有,就会返回没有权限的错误
  • 如果有权限,mysql根据优化器生成的执行计划,调用存储引擎的 API 来执行查询

最后将结果返回给客户端,并且会将结果存放到查询缓存中

参考 -- MySQL 查询执行的过程 - Java程序员进阶 - 博客园


http://www.kler.cn/a/564588.html

相关文章:

  • Redis离线安装(内网,源码安装)
  • 小白向-python实现插入排序算法
  • 大白话React Hooks,新特性怎么用?
  • Trae根据原型设计稿生成微信小程序密码输入框的踩坑记录
  • 使用优化版的编辑距离算法替代ES默认的评分算法
  • 结构体介绍及内存大小分配问题
  • 有没有什么免费的AI工具可以帮忙做简单的ppt?
  • 【C++ 真题】P2661 [NOIP 2015 提高组] 信息传递
  • 【JavaSE-1】初识Java
  • QT:QT场景视图
  • 材料分析方法和特点
  • JUC (java. util.concurrent) 的常见类及创建新线程的方法等 [Java EE 初阶]
  • 【缓存】缓存雪崩与缓存穿透:高并发系统的隐形杀手
  • MongoDB#Code和Function
  • Axure PR 9 中继器 03 翻页控制
  • 计算机网络之传输层(传输层的功能)
  • Ray Data 内部架构深度解析
  • C++ algorithm之shuffle函数
  • 光速解决phpstudy无法启动MySQL服务
  • Java—初始多线程