MySQL一条SQL语句的执行过程?

MySQL一条SQL语句的执行过程

MySQL一条SQL语句的执行过程可以大致分为以下几个步骤:

图片

注意:请点击图像以查看清晰的视图!

1. 连接器(Connection Phase)

首先,客户端与MySQL服务器建立连接,这一阶段由连接器负责处理,包括进行身份验证和权限确认等。

主要包括以下任务:

  • 进行身份验证:验证客户端连接的身份,如用户名和密码。

  • 权限确认:确认客户端是否有权限访问特定的数据库和表。

  • 配置设置:设置连接参数,如字符集、事务处理模式等。

2. 查询缓存(Query Cache)

MySQL会检查查询缓存,如果所需查询的结果已经存在于缓存中,便直接返回缓存结果,从而省略后续的查询过程。查询缓存可以提高查询效率,特别是对于重复执行的查询。

3. 解析器和预处理器(Parser and Preprocessor)

当查询未命中缓存时,MySQL会运用解析器和预处理器对查询语句进行解析,验证语法正确性,并将查询语句转换为内部数据结构。

具体包括以下步骤:

  • 词法分析:将SQL语句分解为关键字、表名、列名、运算符等词汇。

  • 语法分析:检查分解后的词汇是否符合SQL语法规则,生成语法树。

  • 预处理:根据语法树,对查询语句进行预处理,如替换表名、检查约束条件等。

4. 优化器(Optimizer)

MySQL优化器根据查询语句的结构、表的统计信息等因素,生成多个可能的执行计划,并通过成本估算器挑选出最优的执行计划。

优化器根据以下因素生成多个可能的执行计划:

  • 查询语句的结构:如单表查询、多表连接、聚合操作等。

  • 表的统计信息:如表的大小、索引的使用情况等。

  • 系统配置:如缓存大小、CPU核心数等。

优化器还会使用成本估算器(Cost-based Optimizer)挑选出最优的执行计划。

5. 执行器(Executor)

执行器按照优化器选定的执行计划,调用存储引擎的API来执行查询,获取所需数据。

具体包括以下步骤:

  • 生成执行计划:根据优化器生成的执行计划,生成具体的执行步骤。

  • 调用存储引擎:根据执行步骤,调用存储引擎的API读取或写入数据。

  • 返回结果:将查询结果返回给客户端。

6. 存储引擎(Storage Engine)

存储引擎负责实际的数据存储和检索,根据执行器的请求,读取或写入数据。

根据执行器的请求,执行以下任务:

  • 读取数据:从磁盘或其他存储介质中读取数据。

  • 写入数据:将数据写入磁盘或其他存储介质。

  • 数据处理:对数据进行计算、排序等操作。

需要指出的是,MySQL采用分层架构,其中连接器、查询缓存、解析器、优化器、执行器等功能属于Server层,而存储引擎主要负责数据存储和检索。

MySQL支持多种存储引擎,例如InnoDB、MyISAM等,各种存储引擎在数据存储和检索方面可能有差异。

总之,这是MySQL执行一条SQL语句的大致过程。但具体执行过程可能受到查询语句复杂性、表的大小、索引使用等因素的影响。

举个例子

举个例子,MySQL执行一条简单的查询语句select * from users where age='18' and name='tom'的执行流程如下:

  1. 首先,通过连接器,客户端与MySQL服务器建立连接,并完成身份认证和权限验证过程。在此过程中,客户端需要提供用户名和密码以证明其合法性,服务器则会对这些信息进行核对。

  2. 检查是否开启缓存(Mysql8.0之前),开启了 Query Cache 且命中完全相同的 SQL 语句,则将查询结果直接返回给客户端;

  3. MySQL的解析器会对查询语句进行解析,检查语法是否正确,并将查询语句转换为内部数据结构。如查询是select、表名users、条件是age='18' and name='tom',预处理器则会根据MySQL的规则进一步检查解析树是否合法,如检查数据表或数据列是否存在等。

  4. 优化器会根据查询语句的结构、表的统计信息等因素,生成多个可能的执行计划,并通过成本估算器选出最优的执行计划。这一步旨在提高查询效率,降低资源消耗。

  5. 执行器按照优化器选择的执行计划,调用存储引擎的API来执行查询。存储引擎负责实际的数据存储和检索,根据执行器的请求,读取或写入数据。

  6. 存储引擎负责实际的数据存储和检索工作,根据执行器的请求,读取或写入数据。

  7. 若开启了 Query Cache,则缓存,否则直接返回。

图片

  • 9
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值