美文网首页
MYSQL 执行流程

MYSQL 执行流程

作者: 孙瑞锴 | 来源:发表于2021-02-22 00:35 被阅读0次

1. 借鉴

极客时间MySQL实战45讲 力推
MySQL实战 | 01-当执行一条 select 语句时,MySQL 到底做了啥?
Query Cache,看上去很美
mysql: show processlist 详解
MySQL processlist的state属性详解
一句 mysql#show processlist 引发的思想“革命”
Mysql源码学习——词法分析MYSQLlex
MySQL-词法分析
MySQL · 源码分析 · 词法分析及其性能优化
MySQL内核源码解读-SQL解析之解析器浅析
【Mysql源码分析】mysql词法分析
【Golang源码分析】解析执行命令complie(二)词法解析
编译原理之lex,yacc学习
Lex+YACC详解
YACC基本用法
这个翻译的跟屎一样的是答案:无法编译flex&bison(未找到符号x86_64) (Can't compile flex & bison (Symbols not found x86_64))
SQL解析在美团的应用
MySQL架构与SQL执行流程

2. 开始

MYSQL基础架构

MYSQL基础架构

MYSQL大体上可分为Server和存储引擎层。

  • Server层主要包含(简记为:CAOE)连接器,分析器,优化器,执行器,所有的内置函数以及存储过程,触发器,视图。
  • 存储引擎层负责数据的存取和提取,如InnoDB,MyISAM,Memory。
  • MYSQL在8.0+去除掉了查询缓存

那当我们执行一条sql如SELECT ID,NAME FROM T_USER WHERE USER_ID = 1;,MYSQL都做了些什么呢?我们来看看mysql的执行流程

MYSQL执行流程

连接器

首先,我们先连接到mysql中,此时接受连接请求的是server层的连接器,连接器负责跟客户端建立连接、获取权限、维持和管理连接。
我们使用mysql的客户端来连接mysql,在完成TCP三次握手之后,连接器首先会验证身份,然后根据权限表验证身份。

mysql -h127.0.0.1 -P3306 -uroot -p123456

连接完成后,如果没有其他操作,使用show processlist可以看到一个sleep的空闲连接。但是如果长时间没有操作,连接器会自动将其断开,时间长短由wait_timeout参数控制,默认是8小时[28800秒](可以使用SHOW VARIABLES LIKE 'wait_timeout';命令查看)。

mysql> show processlist;
+----+------+-----------------+-----------+---------+------+-------+------------------+
| Id | User | Host            | db        | Command | Time | State | Info             |
+----+------+-----------------+-----------+---------+------+-------+------------------+
|  5 | root | localhost:54000 | metastore | Sleep   |    6 |       | NULL             |
|  6 | root | localhost:54002 | NULL      | Query   |    0 | init  | show processlist |
+----+------+-----------------+-----------+---------+------+-------+------------------+
2 rows in set (0.00 sec)

我启动两个客户端,其中一个Sleep(空闲),另一个Query(执行show processlist;)。另外show processlist;只显示100行数据,如果有太多连接,可以使用show full processlist;

分析器

① 词法分析

登录认证之后,MYSQL要执行语句需要知道具体要干啥,需要对语句进行解析。MYSQL首先会对语句进行词法分析。MYSQL需要识别出语句中的关键词以及各个子串代表什么。如从我们上边的查询中识别出SELECT代表一个查询语句,将T_USER识别为表名,将ID和NAME识别为列。

② 语法分析

做完词法分析后,根据词法分析的结果,语法分析器会根据语法规则,判断输入的这个SQL语句是否满足MySQL语法。
如果语法不通过,会报You have an error in your SQL syntax;的提示。
语法通过,分析之后会生成语法树。

SELECT ID,NAME FROM T_USER WHERE AGE > 25 AND LEVEL >= 6;

如以上sql的语句会生成以下语法树:


语法树
③ 总结

MYSQL分析器自实现了词法分析,语法分析使用Bison实现,有关lex,bison,yacc具体可以参照借鉴中的文章,尤其是美团的那篇以及lex,yacc相关介绍篇,算是可以简单入个门。

优化器

经过分析器,MYSQL知道了我们的SQL具体应该如何执行,但是在开始执行之前,需要先优化一番,好吧,我承认这个优化有时候怪怪的,比如选错索引。
比如优化器在表中有多个索引的时候,决定使用的索引;在表进行join时,决定各个表的join顺序;在order by和group by使用的索引;无用条件去除。

执行器

经过优化器的优化,就开始执行语句了。
开始执行时,先查询权限表判断当前用户对表是否有操作的权限,如果没有就会报denied to user 'test'@'localhost' for table 'T_USER'
如果用户有权限,就会打开表继续执行,执行器根据表的引擎的定义,执行引擎提供的接口,执行流程就如下面这个顺序图所画。图中所画为未使用索引的流程,如果用到了索引,就会调用存储引擎的其他接口。

执行器执行流程

3. 大功告成

极客时间的这个课程真的很不错,以上是基于课程的自我理解与整理

相关文章

  • mysql小知识整理

    1 mysql执行流程 执行mysql,首先你要获取到mysql一个连接,建立连接之后,开始正式sql语句流程:首...

  • 01-SQL语言

    一、MySQL发送SQL请求执行流程MySQL发送SQL请求执行流程.png 1、客户端发送一条给 2、MySQL...

  • MySQL执行流程

    简版执行流程图 待分析SQL如下: 我们看到的只是输入一条语句,返回一个结果,却不知道这条语句在 MySQL 内部...

  • MYSQL 执行流程

    1. 借鉴 极客时间MySQL实战45讲 力推[https://time.geekbang.org/column/...

  • MySQL执行流程

    MySQL执行流程 一共会经历四步,分别是连接、分析、优化与执行。 连接器 连接器会拿着我们输入的IP和端口,去做...

  • mysql执行流程

    数据库在系统应用中处于核心位置。个人对数据库的定义是对数据进行中转或存储的组件都可以称之为数据库;熟悉的非关系型数...

  • mysql执行流程

    server层 包括 连接器,查询缓存,分析器,优化器,执行器等,所有内置函数,所有跨存储引擎的功能(存储过程,视...

  • 99 MySQL性能实战优化

    mysql 性能优化 一 MySQL架构与执行流程原理 二 MySQL 索引底层实现原理 三 MYSQL事务...

  • MySQL源码分析之SQL函数执行

    1.MySQL中执行一条SQL的总体流程 2.SQL函数执行过程 1.MySQL中执行一条SQL的总体流程 一条包...

  • Innodb引擎下的日志系统(WAL)

    说到mysql的数据的日志系统,我们必须先说说MySQL的执行流程: 上图就是我简单的画了一个sql执行流程,不做...

网友评论

      本文标题:MYSQL 执行流程

      本文链接:https://www.haomeiwen.com/subject/eedjsktx.html