一条sql语句是如何执行的?

bloger 2020-11-17 PM 182℃ 0条

我们在执行sql的时候,常常是直接写好值行即可、不是所有人都会思考一下这一条sql是如何值行的?比如


select * from `user` where `uid` = 110;

输入一条语句,那么他的值行过程是怎样的呢?经过拆解下面大概是一条sql的执行流程;

32131.jpg

连接器

php客户端通过pdo、mysqli 链接mysql,如果用户名密码认证通过,连接器会到权限表里面查出你拥有的权限。之后,这个连接里面的权限判断逻辑,都将依赖于此时读到的权限;

查询缓存

MySQL 拿到一个查询请求后,会先到查询缓存看看,之前是不是执行过这条语句。之前执行过的语句及其结果可能会以 key-value 对的形式,被直接缓存在内存中。key 是查询的语句,value 是查询的结果。如果你的查询能够直接在这个缓存中找到 key,那么这个 value 就会被直接返回给客户端。

需要注意的是,查询缓存只建议在不经常变动的表中使用,频繁更新的表会清空cache,导致命中率很低;MySQL 8.0 版本直接将查询缓存的整块功能删掉了,也就是说 8.0 开始彻底没有这个功能了。

分析器

如果没有命中查询缓存,就要开始真正执行语句了。首先,MySQL 需要知道你要做什么,因此需要对 SQL 语句做解析;简而言之 分析器就是分析语法是否正确,分析语法是否满足mysql;

优化器

优化器是在表里面有多个索引的时候,决定使用哪个索引;或者在一个语句有多表关联(join)的时候,决定各个表的连接顺序

执行器

MySQL 通过分析器知道了你要做什么,通过优化器知道了该怎么做,于是就进入了执行器阶段,开始执行语句。

标签: none

非特殊说明,本博所有文章均为博主原创。

评论啦~