iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >SQL语句执行深入讲解(MySQL架构总览->查询执行流程->SQL解析顺序)
  • 703
分享到

SQL语句执行深入讲解(MySQL架构总览->查询执行流程->SQL解析顺序)

2024-04-02 19:04:59 703人浏览 独家记忆
摘要

前言: 一直是想知道一条sql语句是怎么被执行的,它执行的顺序是怎样的,然后查看总结各方资料,就有了下面这一篇博文了。 本文将从Mysql总体架构--->查询执行流程--->语句执行顺序来探

前言:

一直是想知道一条sql语句是怎么被执行的,它执行的顺序是怎样的,然后查看总结各方资料,就有了下面这一篇博文了。

本文将从Mysql总体架构--->查询执行流程--->语句执行顺序来探讨一下其中的知识。

一、MySQL架构总览:

架构最好看图,再配上必要的说明文字。

下图根据参考书籍中一图为原本,再在其上添加上了自己的理解。

 SQL语句执行深入讲解(MySQL架构总览->查询执行流程->SQL解析顺序)

从上图中我们可以看到,整个架构分为两层,上层是mysqlD的被称为的‘SQL Layer',下层是各种各样对上提供接口的存储引擎,被称为‘Storage Engine Layer'。其它各个模块和组件,从名字上就可以简单了解到它们的作用,这里就不再累述了。

二、查询执行流程

下面再向前走一些,容我根据自己的认识说一下查询执行的流程是怎样的:

1.连接

  1.1客户端发起一条Query请求,监听客户端的‘连接管理模块'接收请求

  1.2将请求转发到‘连接进/线程模块'

  1.3调用‘用户模块'来进行授权检查

  1.4通过检查后,‘连接进/线程模块'从‘线程连接池'中取出空闲的被缓存的连接线程和客户端请求对接,如果失败则创建一个新的连接请求

2.处理

  2.1先查询缓存,检查Query语句是否完全匹配,接着再检查是否具有权限,都成功则直接取数据返回

  2.2上一步有失败则转交给‘命令解析器',经过词法分析,语法分析后生成解析树

  2.3接下来是预处理阶段,处理解析器无法解决的语义,检查权限等,生成新的解析树

  2.4再转交给对应的模块处理

  2.5如果是SELECT查询还会经由‘查询优化器'做大量的优化,生成执行计划

  2.6模块收到请求后,通过‘访问控制模块'检查所连接的用户是否有访问目标表和目标字段的权限

  2.7有则调用‘表管理模块',先是查看table cache中是否存在,有则直接对应的表和获取,否则重新打开表文件

  2.8根据表的meta数据,获取表的存储引擎类型等信息,通过接口调用对应的存储引擎处理

  2.9上述过程中产生数据变化的时候,若打开日志功能,则会记录到相应二进制日志文件中

3.结果

  3.1Query请求完成后,将结果集返回给‘连接进/线程模块'

  3.2返回的也可以是相应的状态标识,如成功或失败等

  3.3‘连接进/线程模块'进行后续的清理工作,并继续等待请求或断开与客户端的连接

一图小总结

SQL语句执行深入讲解(MySQL架构总览->查询执行流程->SQL解析顺序) 

三、SQL解析顺序

接下来再走一步,让我们看看一条SQL语句的前世今生。

首先看一下示例语句


SELECT DISTINCT
 < select_list >
FROM
 < left_table > < join_type >
JOIN < right_table > ON < join_condition >
WHERE
 < where_condition >
GROUP BY
 < group_by_list >
HAVING
 < having_condition >
ORDER BY
 < order_by_condition >
LIMIT < limit_number >
您可能感兴趣的文档:

--结束END--

本文标题: SQL语句执行深入讲解(MySQL架构总览->查询执行流程->SQL解析顺序)

本文链接: https://www.lsjlt.com/news/51427.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作