MySQL基本架构&SQL语句在数据库框架中的执行流程&数据库的三范式

MySQL基本架构图:

MySQL主要分为Server层存储引擎层

Server层:

**连接器:**连接客户端,获取权限,管理连接

**查询缓存(可选):**在执行查询语句之前会先到查询缓存中查看是否执行过这条语句,如果执行过那就直接返回缓存中的结果,优点是命中缓存时效率很高,缺点是很难命中,只要任意一个表更新了,所有表的查询缓存都会清空,MySQL8.0已经删除了查询缓存

**分析器:**对SQL语句进行词法分析和语法分析,判断语句是否合法

**优化器:**对SQL语句进行优化,查看是否使用索引

**存储引擎层:**存储数据,提取数据,架构是插件式的,支持InnoDB MyISAM等多个存储引擎。从MySQL5.5.5开始默认是InnoDB,但是在建表的时候可以使用engine = MyISAM 来执行存储引擎为MyISAM,不同存储引擎的存取方式不同,支持的功能也不同。

SQL语句在数据库框架中的执行流程:

  1. 连接器:通过链接器客户端与服务器建立连接
  2. 查询缓存:服务器拿到SQL,先查看是否可以使用缓存
  3. 分析器:如果没有命中缓存,通过分析其开始对语句进行词法分析、解析关键词、在进行语法分析、确定语句符合语法规范
  4. 优化器:对语句进行优化,选择索引,确定SQL执行方案
  5. 执行器:判断是否对表有执行权限,如果有权限,就打开表继续执行,根据表的存储引擎定义,通过这个引擎提供的接口获得数据并返回给客户端

数据库的三范式:

  • 第一范式:列的原子性,即数据库表的每一列多事不可分割的原子数据项
  • 第二范式:要求实体的属性完全依赖于主关键字。所谓完全依赖是指不能存储在仅依赖主关键字一部分的属性
  • 第三范式:任何非主属性不依赖于其他非主属性
相关推荐
magic 2451 小时前
实时同步缓存,与阶段性同步缓存——补充理解《补充》
java·redis·mysql
hqxstudying1 小时前
Redis击穿,穿透和雪崩详解以及解决方案
java·数据库·redis·缓存
斯普信专业组1 小时前
RabbitMQ仲裁队列高可用架构解析
分布式·架构·rabbitmq
Lowcode0022 小时前
边缘计算新基建:iVX 轻量生成模块的 ARM 架构突围
arm开发·架构·边缘计算
檀越剑指大厂2 小时前
【数据库系列】bulk_save_objects 与 bulk_insert_mappings 对比
运维·服务器·数据库
Z.Virgil3 小时前
【案例94】笛卡尔积导致报“临时表空间不足”
java·运维·服务器·开发语言·数据库·sql
铃木隼.3 小时前
MySQL数据库(一)
数据库·mysql·oracle
kgcc4 小时前
MySQL数据库操作
运维·数据库·mysql
hstar95274 小时前
三十一、面向对象底层逻辑-SpringMVC九大组件之RequestToViewNameTranslator接口设计哲学
java·spring·设计模式·架构
not coder4 小时前
Pytest 是什么
数据库·pytest