SQL查询执行流程

在 MySQL 执行一条查询语句的时候,比如SELECT * FROM T WHRER ID = 1,这篇文章来简要的描述SQL查询的执行流程

可以把整体结构分成 Server 层和存储引擎层,Server 层包括连接器查询缓存器分析器优化器执行器。存储引擎层则有常见的 InnoDB,MyISAM,Menory 存储引擎,在 MySQL5.5 后默认使用 InnoDB 存储引擎

一、连接器

客户端连接到 MySQL 服务,连接器负责跟客户端建立连接,获取权限,维持和管理连接

  • 完成 TCP 三次握手,建立连接
  • 输入账号密码,验证身份,并获取用户权限

    这就意味着,一个用户成功建立连接后,即使修改了该用户的权限,也不影响已经存在的连接的权限,修改权限后,只有再新建连接才会使用最新的权限

  • 使用show processlist命令查看连接状态,默认连接保持 8 小时,可以使用wait_timeout来控制

二、查询缓存器

在建立连接后,就可以执行 SELECT 语句了,这时候会先查询缓存,查询缓存器会类似一个 K-V 的缓存,保存着查询语句和对应的返回结果,如果命中的话会直接返回

查询缓存的失效非常频繁,当表数据改变时,会清空所有的缓存数据

在 MySQL8 版本直接就把查询缓存器的整块功能给删除了

三、分析器

如果没有命中缓存的话,就要开始真正的执行语句了

词法分析:检查 SQL 语句拼写是否正确,例如语句中的 SELECT 写成 SELETC 系统就会提示拼写错误

语法分析:检查 SQL 语句是否满足语法要求,例如语句中没有写查询哪个表 系统会提示没指定表,表字段不存在等问题

四、优化器

通过分析器,MySQL 已经知道你要做什么了,但是在这之前还需要进行优化处理,比如:

  • 选择合适的索引
  • 多表 JOIN,对各个表的 JOIN 顺序进行优化
  • SQL 条件的等价替换

五、执行器

根据具体的执行计划,开始执行语句,开始执行的时候,先判断你对这个表是否有执行权限,如果没有则返回没有权限的错误,如果有权限则继续执行

比如这个查询语句: SELECT * FROM T WHRER ID = 1,这个 ID 字段没有索引,那么执行的顺序可能是这样的:

  1. 调用 InnoDB 引擎接口取这个表的第一行,判断 ID 值是不是 1,如果不是则跳过,如果是则将这行存在结果集中;
  2. 调用引擎接口取“下一行”,重复相同的判断逻辑,直到取到这个表的最后一行。
  3. 执行器将上述遍历过程中所有满足条件的行组成的记录集作为结果集返回给客户端。

参考:

  • 《MySQL45 讲》
  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值