MYSQL整体架构以及SQL执行流程

发布于:2024-09-05 ⋅ 阅读:(68) ⋅ 点赞:(0)

视频讲解:MYSQL整体架构以及SQL执行流程说明_哔哩哔哩_bilibili

一 整体架构和执行流程

【通俗讲解】

【实际整体架构和执行流程】

二 MYSQL核心组件

  1. 连接池:管理客户端与服务器之间的连接,包括建立、管理和关闭连接。

  2. 查询缓存:在较旧版本的MySQL中存在,用于缓存查询及其结果。在MySQL 8.0中已经被移除,因为维护成本高且容易失效。

  3. 分析器:解析SQL语句,检查其语法正确性。

  4. 优化器:决定查询的最佳执行计划。例如,如果一个查询涉及多个表的连接,优化器会确定最有效的连接顺序。

  5. 执行器:根据优化器生成的执行计划来执行SQL语句。执行器负责读取数据、处理数据,并返回结果给用户。

  6. 存储引擎:处理数据的物理存储。不同的存储引擎提供了不同的特性,比如InnoDB支持事务和行级锁定,MyISAM不支持事务但对读密集应用更优。

三 SQL执行流程

  1. 连接处理:首先,客户端通过TCP/IP或其他协议与MySQL服务器建立连接。

  2. 解析SQL:MySQL服务器接收到SQL查询后,会先对其进行语法解析,确保SQL语句符合MySQL的语法规则。

  3. 查询缓存检查:虽然在MySQL 8.0中已经移除了全局查询缓存,但在一些情况下,如使用了内存表或特定的缓存插件,仍然可能存在某种形式的缓存机制。

  4. 查询优化:查询优化器分析查询并选择最佳的执行计划。这包括决定访问哪些表、按照什么顺序访问以及如何有效地使用索引等。

  5. 执行查询:根据优化后的执行计划,MySQL执行器开始执行查询。这可能涉及到从存储引擎检索数据、处理数据、应用任何需要的过滤条件等等。

  6. 返回结果:一旦查询执行完成,MySQL将结果集发送回客户端。

  7. 清理和断开连接:查询结束后,MySQL会释放分配给该查询的资源,并且在适当的时候断开客户端连接。

四 InnoDB处理数据的具体步骤

1. 缓存检查

  • InnoDB首先会在缓冲池(Buffer Pool)中查找所需的数据页。缓冲池是一个重要的内存结构,用于缓存表的数据和索引。
  • 如果数据页已经在缓冲池中,则直接从内存中读取数据。
  • 如果数据页不在缓冲池中,InnoDB会从磁盘读取数据页到缓冲池。

2. 数据页读取

  • 当数据页需要从磁盘读取时,InnoDB会发起一个异步IO请求。
  • 数据页被加载到缓冲池后,InnoDB会对页中的数据进行解密(如果使用了行加密功能)。

3. 行查找

  • InnoDB使用主键或其他唯一索引来定位具体的行。
  • 如果只需要索引中的列(覆盖索引),那么可以直接从索引页中获取数据;否则,需要再通过主键索引找到对应的行数据。

4. 加锁

  • 在多用户环境中,InnoDB为了保证事务的一致性和隔离性,会使用行级锁来控制并发访问。
  • 锁的类型取决于事务隔离级别和查询的性质(如共享锁或排他锁)。

5. 返回结果

  • 一旦数据被成功读取并且所有必要的处理完成,结果就会被返回给MySQL服务器。
  • MySQL服务器整理结果集,并发送给客户端。