首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL Select语句怎么执行的?

MySQL Select语句怎么执行的?...今天分享的内容是select和update的执行流程。 select的执行过程 话不多说,来个神图镇楼(自己画的)。...[7goo7i5di4.png] 首先,我们可以看到,整个select语句包含三个模块,其中客户端和MySQL两个部分,MySQL又包含server端和存储引擎侧,server端包含连接器、查询缓存...查询缓存: 当客户端输入一个SQL之后,如果命中查询缓存,那么MySQL将会直接返回结果,而不进行下面的一系列分析操作,如果没有命中,则开始进入分析器---优化器---执行器这个流程。...A1:有些时候,SQL语句要操作的表不只是SQL字面上那些。比如如果有个触发器,得在执行器阶段(过程中)才能确定。优化器阶段前是无能为力的 Q2:MySQL权限到底在哪里验证?

2.3K40

MySQL Update语句怎么执行的?

MySQL Update语句怎么执行的?...[isd2tnp037.png] 昨天,我们利用这张图,了解了一个select语句执行过程,讲解了连接器、查询缓存、分析器、优化器、执行器等模块的作用,今天我们来看一条update语句怎么执行的...其实,update语句执行过程和select语句差不多,但是在update语句执行的过程中,MySQL新增加了两个重要的日志模块,他们分别是redo log(重做日志)和binlog(二进制日志、也可以称之为归档日志...当我们执行一个update的SQL时,MySQL会干如下几件事情: a、执行器查找指定记录,如果记录所在的数据页在内存中,就直接返回给执行器;否则,需要先从磁盘读入内存,然后再返回。...在这个过程中,MySQL server端的执行器和innodb存储引擎频繁进行交互,画成流程图就是: [owf6lim4ed.png] 其中,涂蓝色的是在Server层面执行的,白色框代表在Innodb

4.5K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL》系列 - select 语句怎么执行的?

    为此,我画了张 mysql 的架构图(你也可以理解为 sql 查询语句执行过程),如下所示: ? Mysql 架构图 首先 msql 分为 server 层和存储引擎层两个部分。...MySQL 是个聪明的仔,再执行之前会自己优化下客户端传过来的语句,看看那种执行起来不那么占内存、快一点。...两种方案的执行结果是一样的,但是效率不一样、占用的资源也就不一样。优化器就是在选择执行的方案。它优化的是索引应该用哪个?多表联查应该先查哪个表?怎么连接等等。...1.5 执行器 分析器知道了做啥、优化器知道了应该怎么做。接下来就交给执行器去执行了。 开始执行,判断是否有相应的权限。...巨人的肩膀 https://time.geekbang.org/column/article/68319 总结 本文通过一条简单的 SQL 查询语句,引出 MySQL 的结构以及这条 sql 查询语句执行流程

    2.2K20

    mysql语句怎么拼接字符串_MySQL执行拼接字符串语句实例

    — 以下是一个MySQL执行拼接字符串语句实例:– 为需要拼接的变量赋值SET @VARNAME= — 以下是一个MySQL执行拼接字符串语句实例: — 为需要拼接的变量赋值 SET @VARNAME...是执行拼接字符串语句的参数,@TestName是结果值 SET @SQLStr0=CONCAT(‘SELECT TestName INTO @TestName FROM test.t_TestTable...,@VARNAME,’%” LIMIT 1;’); — 预处理拼接好的字符串 PREPARE SQLStr1 FROM @SQLStr0; — 为参数赋值 SET @Test_ID=1; — 使用参数执行拼接好的字符串语句...EXECUTE SQLStr1 USING @Test_ID; — 释放拼接的字符串语句 DEALLOCATE PREPARE SQLStr1; SELECT @TestName;– 获取结果值 —...%” LIMIT 1;’; — 为参数赋值 SET @Test_ID=1; SET @VARNAME=’李’; — 使用参数执行拼接好的字符串语句 EXECUTE SQLStr1 USING @Test_ID

    3.1K20

    Mysql查询语句执行流程

    第二部:   查询缓存 mysql拿到请求后首先判断请求的查询语句是否有缓存,是否命中缓存,但是不推荐使用mysql的缓存,官方也不推荐,因为只要有一条数据更新表的缓存就会被删除,降低效率 第三步:   ...分析器 没有命中缓存的话就要开始执行语句了,首先对sql语句进行解析, 首先做 “词法解析”,分析出sql语句的关键词等字符串代表什么含义,然后通过”语法分析“判断这个sql是否满足语法标准。...第四步:   优化器 优化sql执行的速度,比如执行的索引、表连接(join)的执行顺序,然后决定出最快的执行方案 第五步:   执行器 判断用户对这个表是否有权限,有的话就会根据这个表的引擎执行通过优化器给出的最优执行方案去执行

    4.3K10

    Mysql语句执行过程

    当你希望MySQL能够以更高的性能运行查询时,最好的办法是弄清楚MySQL是如何优化和执行查询。...《高性能MySQL》 衡量查询开销的三个指标 响应时间扫描的行数 服务时间(处理这条语句真正花的时间) 排队时间(等待资源,例如IO,行锁等) 扫描的行数 返回的行数 当删除了搜索条件列的索引时,语句进行全表扫描...查询的执行流程 ? 图二 语句的处理过程 1.连接数据库 客户端发起一条Query请求,监听客户端的‘连接管理模块’接收请求。 将请求转发到‘连接进/线程模块’。 调用‘用户模块’来进行授权检查。...命中查询缓存,用户权限没有问题,MySQL直接从缓存中拿结果返回给客户端。 查询优化处理(解析SQL、预处理、优化SQL的执行计划),将SQL转化成一个执行计划。...优化过程书上介绍了很多情况,请参考书籍6.43章 执行计划 MySQL会生成一个指令树,然后通过存储引擎完成这棵树并返回结果 如图2 查询执行引擎  查询执行引擎则根据执行计划来完成整个查询。

    2.6K20

    Mysql系列】(一)MySQL语句执行流程

    MySQL 服务器接收到 SQL 语句后,会执行相应的操作,比如查询、插入、更新等。 MySQL 服务器执行完 SQL 语句后,会将结果返回给 MySQL 客户端程序。...需要注意的是,「MySQL 默认长连接时间是 8 小时」 因为长连接导致 OOM 怎么办 如果长连接导致了内存不足(OOM),可以考虑以下几种方式来解决该问题: 减少连接池中的连接数:如果连接数过多导致内存不足...MySQL 查询缓存的工作原理如下: 当执行一个查询语句时,MySQL 会首先检查查询缓存,看看是否有与当前查询语句完全匹配的缓存结果。...MySQL 优化器是一个智能的查询执行计划生成器,它会根据查询语句和表的信息,通过优化算法来选择最佳的查询执行策略。...执行器 什么是 MySQL 执行MySQL 执行器(MySQL Executor)是 MySQL 数据库的一个组件,负责执行查询语句并返回结果。

    36830

    MySql基础架构(sql查询语句MySql内部具体是怎么执行的?)

    直到有一个面试官问我一个问题,一条sql查询语句mysql数据库中具体是怎么执行的?我被虐了,很开心,感谢他。于是开始了深入学习mysql。...本篇文章通过 一条sql查询语句mysql数据库中具体是怎么执行的? 来具体讲解mysql的基础架构。...Mysql确定了查询语句,会先到查询缓存中,看之前是否执行过这条查询语句。之前如果执行过这条查询语句,查询结果可能会以key-value的方式直接缓存在内存中。...分析器 如果在查询缓存中未找到缓存数据,就会开始真正的执行查询语句Mysql需要直到这条查询语句要做什么?因此需要对SQL语句做解析。...ounter(line 执行MySQL 通过分析器知道了你要做什么,通过优化器知道了该怎么做(执行方案是什么?),于是就进入了执行器阶段,开始执行语句

    5.6K20

    MySQL执行sql语句的机制

    目录 1 概念 2 执行过程 1 概念 连接器: 身份认证和权限相关(登录 MySQL 的时候)。...查询缓存: 执行查询语句的时候,会先查询缓存(MySQL 8.0 版本后移除,因为这个功能不太实用)。...第二步,语法分析,主要就是判断你输入的 sql 是否正确,是否符合 MySQL 的语法。 优化器: 按照 MySQL 认为最优的方案去执行执行器: 执行语句,然后从存储引擎返回数据。...,然后调用数据库引擎,返回执行结果 更新(包括删除、新增)语句执行执行更新语句时会就日志:归档日志和重做日志, 1、先查询数据 2、然后将查出的数据修改,调用引擎API接口写入这一行数据,InnoDB...SQL 等执行过程分为两类, 一类对于查询等过程如下:权限校验—-》查询缓存—-》分析器—-》优化器—-》权限校验—-》执行器—-》引擎 对于更新等语句执行流程如下:分析器——》权限校验——》6267

    3.8K30
    领券