【MySQL是怎么运行的一】逻辑架构

MySQL可以分为连接层、服务层和引擎层

连接层

  1. 客户端发起请求,MySQL服务器会从数据库连接池中取出一个线程对接,TCP三次握手后建立连接。
  2. 客户端发起身份验证(用户名、密码),验证失败:Access denied for user,验证成功则连接成功

服务层

**SQL api:**提供api供客户端调用,如crud

**缓存:**相同的请求缓存一份结果,因为命中率低,新版本MySQL已经废弃

**解析器:**将原始sql经过预发解析后生成语法树,会校验sql语法是否正确,用户是否有权限等

**优化器:**对sql进行优化处理,生成执行计划

sql 复制代码
CREATE TABLE s1
(
    id           INT AUTO_INCREMENT,
    key1         VARCHAR(100),
    key2         INT,
    key3         VARCHAR(100),
    key_part1    VARCHAR(100),
    key_part2    VARCHAR(100),
    key_part3    VARCHAR(100),
    common_field VARCHAR(100),
    PRIMARY KEY (id),
    KEY idx_key1 (key1),
    UNIQUE KEY idx_key2 (key2),
    KEY idx_key3 (key3),
    KEY idx_key_part (key_part1, key_part2, key_part3)
) ENGINE = INNODB
  CHARSET = utf8;

初始sql是这样的,不符合最左匹配原则

sql 复制代码
explain 
select *
from s2
where key_part2 = 'a'
  and key_part1 = 'b';

经过优化器优化后变为

sql 复制代码
explain
select *
from s2
where key_part1 = 'b'
  and key_part2 = 'a';

结果

引擎层

负责物理数据的读取和写入,直接与磁盘打交道,通过api与服务层交互

相关推荐
倔强的石头_16 小时前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横16 小时前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二16 小时前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
冬奇Lab1 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
小猿姐1 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
只会cv的前端攻城狮1 天前
DSL 领域模型架构设计:消灭 CRUD 重复工作
前端·架构
ClouGence2 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
禅思院2 天前
路由性能优化终极指南:从懒加载漏洞到边缘渲染的架构跃迁
前端·架构·前端框架
怕浪猫2 天前
Electron 系列文章封面图
算法·架构·前端框架