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

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

目录

mysql架构查询执行流程

图解

描述 


mysql架构查询执行流程

图解

描述 

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

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

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

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

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

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

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

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

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

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

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

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

相关文章:

  • WPF高级 | WPF 3D 图形编程基础:创建立体的用户界面元素
  • ChatGPT 提示词框架
  • mysql数据迁移到SQLserver: 构建数据迁移脚本
  • 2025年网校系统源码开发趋势:技术革新的教育培训APP搭建实战
  • WPF11-附加属性
  • 推荐律师事务管理系统(SpringCloud+mysql+rocketmq+deepseek)
  • Qt 中,**信号与槽(Signals Slots)机制
  • docker通用技术介绍
  • 基于Python socket库构建的基于 P2P 的文件共享系统示例
  • 深入理解消息队列
  • 【TypeScript】TypeScript的应用实例
  • 重磅 | Cloud Ace 推出 GenAIOps 服务:加速企业生成式 AI 商业落地
  • wayland桌面录屏,屏幕录制,Linux屏幕录制
  • (功能测试)第五章 APP性能测试 常用的APP命令格式 补充与总结
  • React + TypeScript 数据血缘分析实战
  • DeepSeek R1 部署笔记(个人无框架部署,缓慢更新中)
  • Spring AOP 切面打印日志完整版
  • ubuntu离线安装Ollama并部署Llama3.1 70B INT4并对外发布服务
  • 鲲鹏麒麟离线安装Docker
  • 定义数组存储3部汽车对象(class2:类在class1中请看上一篇博客)
  • 吉安市网站建设/免费个人网站源码
  • 福建省建设注册中心网站/全网营销代运营
  • 建设银行网站上改手机号码/上google必须翻墙吗
  • 计算机专业主要学什么课程/保定seo排名外包
  • txt怎么做网站/3d建模培训学校哪家好
  • 中山网站建设品牌/营销型网站更受用户欢迎的原因是