MySQL结构及执行流程

MySQL结构介绍

​ 1. MySQL简化结构

在这里插入图片描述

客户端 : 并非MySQL所独有,诸如 : 连接处理、授权认证、安全等功能均在这一层处理
核心服务 : 包括查询解析、分析、优化、缓存、内置函数(比如 : 时间、数学、加密等函数),所有的跨存储引擎的功能也在这一层实现 : 存储过程、触发器、视图等
存储引擎 : 负责 MySQL 中的数据存储和提取,和 Linux 下的文件系统类似,每种存储引擎都有其优势和劣势,中间的服务层通过 API 与存储引擎通信,这些 API接口 屏蔽不同存储引擎间的差异

  1. MySQL详细结构
    在这里插入图片描述

1、Connectors (连接器组件) :用来支持各种语言和 SQL 的交互,比如 PHP,Python,Java 的 JDBC;

2、Management Serveices & Utilities(管理服务和工具组件):系统管理和控制工具,包括备份恢复、MySQL 复制、集群等等;

3、Connection Pool(连接池组件):连接池,管理需要缓冲的资源,包括用户密码权限线程等 等;

4、SQL Interface(SQL接口组件):用来接收用户的 SQL 命令,返回用户需要的查询结果

5、Parser(解析器组件):用来解析 SQL 语句;

6、 Optimizer(优化器组件):查询优化器;

7、Cache and Buffer(缓冲组件):查询缓存,除了行记录的缓存之外,还有表缓存,Key 缓 存,权限缓存等等;

8、Pluggable Storage Engines(插件式存储引擎):插件式存储引擎,它提供 API 给服务层使用, 跟具体的文件打交道。

注意:

存储引擎是基于表的,而不是数据库。

  1. 体系结构详解

1.连接层
客户端或者应用程序通过接口(如:ODBC,JDBC)来连接MySQL,最先连接处理的就是连接层,连接层包括通信协议,线程处理,用户名密码认证三个部分,通信协议负责检测客户端版本是否与服务端兼容,线程处理是指每一个连接请求都会分配一个对应独立的线程,用户名密码认证创建的账号和密码,以及host主机授权是否可以连接到mysql服务器

2.sql层
sql层包含权限判断,查询缓存,解析器,预处理,查询优化器和执行计划;
1)权限判断可以通过审核用户有没有访问某个库,某个表,或者表里某行的权限。
2)查询缓存通过query cache进行操作,如果数据在query cache中,则直接返回结果给客户端
3)查询解析器针对sql语句进行解析,判断语法是否正确,并生成解析器
4)预处理器解决解析器无法解析的语义
5)优化器对sql语句进行改写和相应的优化,例如:对连接表重排序,对外连接转内连接,代数等价法则,计算和减少常量表达式,自查询优化,早期终结,相等传递等,并生成最优的执行计划,然后就可以调用程序的API接口,通过存储引擎层访问数据;

执行流程

在这里插入图片描述

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值