MySQL基本架构示意图

1.MySQL的基本架构示意图

在这里插入图片描述

MySQL可以基本划分为Server层和存储引擎层两部分,其中Server层包含了连接器、缓存、分析器、优化器和执行器,存储引擎层包含各种存储引擎实现,最常见的有InnoDB、MyISAM和MEMORY。

2.执行流程

  1. 首先客户端与MySQL连接,这部分流程由连接器处理,它包括管理客户端与MySQL的连接之外还包括权限认证。当客户端与MySQL建立连接,MySQL会查询权限表该用户相关权限,存放在该连接绑定的session中,当权限修改时,不会影响已经建立的连接,直到重新建立连接才会生效。
  2. 建立连接之后,客户端提交一个select语句,会首先在缓存中查找,如果能找到则直接返回结果,否则交由分析器处理。缓存是以表为单位的,当对某个表进行更新相关操作时,该表的缓存会全部失效。据了解,缓存的使用往往弊大于利,建议不适用。MySQL 8.0之后的版本已经将查询缓存的整块功能删掉了。
  3. 流程到分析器,分析器对SQL进行词法分析和语法分析,然后根据分析结果再先查找缓存,如若还找不到结果,则走接下来的流程。
  4. 流程到了优化器,由于我们往往会在一个表建多个索引,优化器根据执行,自行决定是否使用索引、使用哪个索引进行查询,然后交由执行器处理。
  5. 最后,执行器根据优化器给出的执行计划,结合连接的权限进行结果查询。
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值