解析器预处理器mysql_深入理解:Mysql执行SQL语句过程

f71df3beb14b134f1de05e4a82348799.png

开发人员基本都知道,我们的数据存在数据库中(目前最多的是mysql和oracle,由于作者更擅长mysql,所以这里默认数据库为mysql),服务器通过sql语句将查询数据的请求传入到mysql数据库。数据库拿到sql语句以后。都是进行了哪些操作呢?这里向大家介绍下我的个人的理解,欢迎大家评论区批评指正。

流程概述

mysql得到sql语句后,大概流程如下:

1.sql的解析器:负责解析和转发sql

2.预处理器:对解析后的sql树进行验证

3.查询优化器:得到一个执行计划

4.查询执行引擎:得到数据结果集

5.将数据放回给调用端。

流程图如下所示:

1fbda3d0e57ae4889d633e3c68d3433b.png

分发器及缓存阶段

首先,如果系统的缓存功能开启着的话,sql语句进入mysql后,sql进行判断,是否为select关键字。如果是,那么先去查询缓存中进行查询,如果在查询缓存中可以命中sql语句,那么直接返回查询缓存中的查询语句对应的value值(在缓存中,把查询语

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值