广告
返回顶部
首页 > 资讯 > 数据库 >MySQL Select语句是如何执行的
  • 878
分享到

MySQL Select语句是如何执行的

MySQLSelect语句MySQLSelect语句执行 2022-05-20 20:05:14 878人浏览 独家记忆
摘要

MySQL Select语句是怎么执行的?    最近在极客时间看丁奇大佬的《Mysql45讲》,真心觉得讲的不错,把其中获得的一些mysql方向的经验整理整理分享给大家,有兴趣同学可以

MySQL Select语句是怎么执行的?

   最近在极客时间看丁奇大佬的《Mysql45讲》,真心觉得讲的不错,把其中获得的一些mysql方向的经验整理整理分享给大家,有兴趣同学可以购买相关课程进行学习

   今天分享的内容是select和update的执行流程。

select的执行过程

话不多说,来个神图镇楼(自己画的)。

   首先,我们可以看到,整个select语句包含三个模块,其中客户端和Mysql两个部分,MySQL又包含server端和存储引擎侧,server端包含连接器、查询缓存、分析器、优化器,执行器等多个部分,存储引擎侧同样包含innodb、Myisam,memory等多种存储引擎。

每个模块的作用如下:

连接器:

   连接器的任务是跟客户端建立连接,查询权限,维持和管理连接等等。当我们使用命令行登录时,如果密码或者账号错误,那么连接器会返回给我们Access Deny的报错,利用正确的账号密码登录到MySQL之后,连接器会查询当前账号的登录权限,之后的所有操作,都是依赖这个权限进行的。

注意,如果此时我们更改了该账号的权限,并不会对已经存在的连接产生影响,而只对新加入的连接产生影响。

   如果客户端连接进入MySQL后,一直没有进行任何操作,那么连接器将会在wait_timeout参数设置的时间后,将该连接断开。建议在程序中使用长连接,这样可以减小和客户端和MySQL建立连接的带来的性能损耗。

查询缓存:

当客户端输入一个SQL之后,如果命中查询缓存,那么MySQL将会直接返回结果,而不进行下面的一系列分析操作,如果没有命中,则开始进入分析器---优化器---执行器这个流程。关于查询缓存,还有2点需要注意:

a、MySQL8.0中开始弃用查询缓存,因为查询缓存的命中率一般较低,弊大于利。

b、在高并发场景中,建议将查询缓存关闭,关闭时使用query_cache_type=off或者query_cache_size=0。

c、如果非要使用这个功能,可以将参数query_cache_type设置成DEMAND,这样,就可以使用select sql_cache  * from table这种方式强制使用查询缓存的功能了。

分析器:

如果我们的查询没有真正命中查询缓存,那么就要进入分析器这个环节了,分析器的主要功能是词法分析和语法分析,其中:

词法分析指的是根据SQL分析出来select、update、alter、列名、表名、库名等;

语法分析是指需要分析你写的SQL是否满足MySQL的语法。如果不满足,则会给出you have an error xxx的提示。

优化器:

   优化器的作用是选出SQL执行的最佳路径,例如在多表join的时候,优化器会选择最高效的方案来执行连接查询。这里可以给出一个例子,例如我们建立了(a,b)的联合索引

select * from table where a=1 and b=1;

select * from table where b=1 and a=1;

这两条SQL是等价的,因为优化器会将下面的改造成上面的样子,从而应用联合索引进行搜索查询。

执行器:

  SQL经过优化器之后,就会进入执行器,执行SQL前,需要校验表的权限,如果有权限,会根据表的存储引擎定义,去使用这个存储引擎提供的接口,最终将数据返回给客户端,并开始等待新的连接。

这里需要注意一点:执行器调用一次,在引擎内部则扫描了多行,因此存储引擎扫描行数跟rows_examined并不是完全相同的。

Q && A

Q1:为什么对权限的检查不在优化器之前做?

A1:有些时候,SQL语句要操作的表不只是SQL字面上那些。比如如果有个触发器,得在执行器阶段(过程中)才能确定。优化器阶段前是无能为力的

Q2:MySQL权限到底在哪里验证?

A2:账号的登录权限在连接器模块验证;表的操作权限分为两种情况,如果命中查询缓存,会在查询缓存放回结果的时候验证,在优化器之前,如果没有命中索引,则权限验证在执行器模块验证。

以上就是MySQL Select语句是如何执行的的详细内容,更多关于MySQL Select语句的资料请关注自学编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL Select语句是如何执行的

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

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

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

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

下载Word文档
猜你喜欢
  • MySQL Select语句是如何执行的
    MySQL Select语句是怎么执行的?    最近在极客时间看丁奇大佬的《MySQL45讲》,真心觉得讲的不错,把其中获得的一些MySQL方向的经验整理整理分享给大家,有兴趣同学可以...
    99+
    2022-05-20
    MySQL Select语句 MySQL Select语句执行
  • mysql select语句的执行顺序
    这篇文章主要讲解了“mysql select语句的执行顺序”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql select语句的执行顺序”吧...
    99+
    2022-10-18
  • MySQL之select 语句的执行顺序
    mysql语句编写顺序 ① select 字段名 ② from 表1 inner|left|right join 表2 on 表1 与表2 的关系… ③ where ... ④ group by ... having ...
    99+
    2018-04-07
    MySQL之select 语句的执行顺序
  • 【MySQL系列】- SELECT语句执行顺序
    【MySQL系列】- SELECT语句执行顺序 文章目录 【MySQL系列】- SELECT语句执行顺序一、MYSQL逻辑查询处理的步骤图二、MYSQL执行顺序详解2.1 执行FROM操作2....
    99+
    2023-10-21
    mysql android 数据库
  • 论一条select语句在MySQL是怎样执行的
    目录一、从宏观的角度分析MySQL二、一条SQL执行要经过多少困难?2-1 连接器2-2 查询缓存2-3 分析器2-4 优化器2-5 执行器一、从宏观的角度分析MySQL 首先看一张经典图片(MySQL逻辑架构图)...
    99+
    2022-05-22
    select执行MySQL语句 MySQL select执行
  • select查询语句该如何执行
    这期内容当中小编将会给大家带来有关select查询语句该如何执行,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。mysql 作为一个关系型数据库,在国内使用应该是...
    99+
    2022-10-19
  • SQL Select语句完整的执行顺序是什么
    这篇文章主要介绍SQL Select语句完整的执行顺序是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!SQL Select语句完整的执行顺序:1、from子句组装来自不...
    99+
    2022-10-18
  • Explain是怎么执行MySQL语句的
    这篇文章主要介绍“Explain是怎么执行MySQL语句的”,在日常操作中,相信很多人在Explain是怎么执行MySQL语句的问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2022-10-19
  • MySQL中一条update语句是如何执行的
    目录前言前期准备SQL语句的执行过程Update语句分析redo log(重做日志)binlog(归档日志)‍♀️总结前言 上一篇文章说完MySQL的事务和锁了,这次来详细介...
    99+
    2022-11-13
  • MySQL的select语句如何使用
    今天小编给大家分享一下MySQL的select语句如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。selec...
    99+
    2023-06-27
  • MySQL SQL语句是如果被执行的?(1)
    语法解析和预处理(Parser & Preprocessor) 假如我们随便执行一个字符串,MySQL服务器会报一个1064的错误: 1064 - You have an error in your SQL syntax; check th...
    99+
    2019-07-25
    MySQL SQL语句是如果被执行的?(1)
  • 一条SQL语句在MySQL中是如何执行的
    今天就跟大家聊聊有关一条SQL语句在MySQL中是如何执行的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。前言最近开始在学习mysql相关知识,自己...
    99+
    2022-10-19
  • Mybatis注解开发@Select执行参数和执行sql语句的方式
    执行传参 @Select 是 Mybatis 框架中的一个注解,用于执行 SQL 查询语句,并把查询结果映射到指定的 Java 对象中。 具体来说,@Select 注解会将注解中的 SQL 查询语句交给 Mybatis 框架进行解...
    99+
    2023-09-17
    mybatis sql java
  • MySQL中一条SQL查询语句是如何执行的
    目录前言1. 处理连接1.1 客户端和服务端的通信方式1.1.1 TCP/IP协议1.1.2 UNIX域套接字1.1.3 命名管道和共享内存1.2 权限验证1.3 查看MySQL连接...
    99+
    2022-11-13
  • mysql的sql语句执行流程
    1、client和server建立连接,client发送sql至server(对应连接器这一过程) 2、server如果在查询缓存中发现了该sql,则直接使用查询缓存的结果返回给client,如果查询缓存中...
    99+
    2022-10-18
  • sql语句在mysql中是怎么执行的
    这篇文章主要介绍了sql语句在mysql中是怎么执行的,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、mysql架构分析下面是mysql的...
    99+
    2022-10-18
  • ​mysql中语句执行顺序是什么
    这篇文章给大家分享的是有关mysql中语句执行顺序是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。MySQL的语句一共分为11步,如下图所标注的那样,最先执行的总是FROM操...
    99+
    2022-10-18
  • JavaScript语句如何执行
    这篇文章主要介绍“JavaScript语句如何执行”,在日常操作中,相信很多人在JavaScript语句如何执行问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JavaScri...
    99+
    2022-10-19
  • MySQL中一条update语句是怎么执行的
    本篇内容主要讲解“MySQL中一条update语句是怎么执行的”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL中一条update语句是怎么执行的”吧!前期准备⭐⭐首先创建一张表,然后插入...
    99+
    2023-06-29
  • MySQL查询语句的执行过程是什么
    这篇文章主要介绍MySQL查询语句的执行过程是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!首先先简单的将一个查询语句背后MySQL做了什么捋一捋:客户端发送一条查询给服务器。服务器先检查查询缓存,如果命中了缓存...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作