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

SQL语句执行过程详解

一、SQL语句执行原理: 第一步:客户端把语句发给服务器端执行 当我们在客户端执行 select 语句时,客户端会把这条 SQL 语句发送给服务器端,让服务器端的 进程来处理这语句。...第三步:语句执行 语句解析只是对 SQL 语句的语法进行解析,以确保服务器能够知道这条语句到底表达的是什么意思。等到语句解析完成之后,数据库服务器进程才会真正的执行这条 SQL 语句。...二是绝大部分 SQL 语句都是按照这个处理过程处理的。我们 DBA 或者基于 Oracle 数据库的开发人员了解这些语句的处理过程,对于我们进行涉及到 SQL 语句的开发与调试,是非常有帮助的。...DBCC FREEPROCCACHE 从过程缓存中删除所有元素。 DBCC FREESYSTEMCACHE 从所有缓存中释放所有未使用的缓存条目 SQL语句中的函数、关键字、排序等执行顺序: 1....二、SQL语句执行完整过程: 1.用户进程提交一个 sql 语句: update temp set a=a*2,给服务器进程。

3.9K60
您找到你想要的搜索结果了吗?
是的
没有找到

浅谈SQL语句执行过程

写在前面的话:有时不理解SQL语句各个部分执行顺序,导致理解上出现偏差,或者是书写SQL语句时随心所欲,所以有必要了解一下sql语句执行顺序。可以有时间自己写一个简单的数据库,理解会更加深入。...没错,对于这样的简单的语句,一眼就能看出来,可是对于稍微复杂一些的SQL语句或者更加复杂的SQL语句,有时我们一眼就看不出来了,为了能够正确分析SQL语句以及写出正确的SQL语句,有必要了解一下SQL语句各部分的执行顺序...语句执行顺序,Table1和Table2如下: ?...Table1        Table2 下面先给出上面的SQL语句执行顺序,然后进行讲解: (8)  select (9)  distinct (11)  top 1 (6)  Table1....经过上面的过程,最终的SQL语句将VT10返回给用户使用。 所以以后再写SQL语句的时候,可以按照上面的顺序写SQL语句了,读SQL语句也可以按照上面的顺序去读,做到心里明白。

1.4K20

MySQL执行SQL语句过程详解

流程概述   MySQL得到sql语句后,大概流程如下:   1.sql的解析器:负责解析和转发sql   2.预处理器:对解析后的sql树进行验证   3.查询优化器:得到一个执行计划   4.查询执行引擎...sql的解析器与预处理   sql解析器是在命令分发之后,将对应的sql语句,解析为sql解析树。sql解析树是MySQL本身内部的语法规则和解析查询。...rbo会根据输入的sql语句可以匹配到的优先级最高的规则去作为执行计划。例如:在rbo中有这么一条规则:有索引的情况下,使用索引。那么所有的带有索引的表在执行的时候,都会走索引。...成本指的是MySQL根据相关的统计信息,算出来sql语句对应的io,cpu等的消耗的一个估计值。计算过程涉及到索引、表、行等数据,过程比较复杂。   ...执行完成后,将结果返回给客户端,如果是查询语句,并且开启了缓存,那么,MySQL会同时将结果集放到查询缓存中。然后将查到的结果集返回。如果是增删改操作,那么返回执行语句后受影响的行数。

3.4K20

MySql的sql语句执行过程详述

前言: 很多人都在使用mysql数据库,但是很少有人能够说出来整个sql语句执行过程是怎样的,如果不了解执行过程的话,就很难进行sql语句的优化处理,也很难设计出来优良的数据库表结构。...这篇文章主要是讲解一下sql语句执行过程sql语句执行过程: 客户端、连接器、分析器、优化器、执行器、存储引擎几个阶段。 连接器的作用:管理链接、权限验证的处理。...连接器: 执行sql语句的时候,第一步需要进行数据库的连接处理,连接器负责客户端建立连接、获取权限、维持和管理连接。...查询缓存: 连接建立完毕之后,进行查询缓存的处理,执行sql语句会先到缓存中看看是不是刚刚执行了这条语句,之前执行过的语句及其结果就会以key-value对的形式直接存储在内存中的,key是查询的语句,...然后进行语法分析的处理,根据词法分析,根据词法分析的结果,语句分析器就会根据语法规则判断输入的这个sql语句是否满足mysql的语法。

20440

MySQL探秘(二):SQL语句执行过程详解

昔日庖丁解牛,未见全牛,所赖者是其对牛内部骨架结构的了解,对于MySQL亦是如此,只有更加全面地了解SQL语句执行的每个过程,才能更好的进行SQL的设计和优化。  ...SQL语句执行过程 查询缓存  MySQL查询缓存保存查询返回的完整结构。当查询命中该缓存时,MySQL会立刻返回结果,跳过了解析、优化和执行阶段。  ...DEMAND表示只有在查询语句中明确写明SQL_CACHE的语句才会放入查询缓存。 query_cache_size:查询缓存使用的总内存空间。...生成执行计划的过程会消耗较多的时间,特别是存在许多可选的执行计划时。...如果在一条SQL语句执行过程中将该语句对应的最终执行计划进行缓存,当相似的语句再次被输入服务器时,就可以直接使用已缓存的执行计划,从而跳过SQL语句生成执行计划的整个过程,进而可以提高语句执行速度。

1.8K30

MySQL探秘(二):SQL语句执行过程详解

昔日庖丁解牛,未见全牛,所赖者是其对牛内部骨架结构的了解,对于MySQL亦是如此,只有更加全面地了解SQL语句执行的每个过程,才能更好的进行SQL的设计和优化。  ...SQL语句执行过程 查询缓存  MySQL查询缓存保存查询返回的完整结构。当查询命中该缓存时,MySQL会立刻返回结果,跳过了解析、优化和执行阶段。  ...DEMAND表示只有在查询语句中明确写明SQL_CACHE的语句才会放入查询缓存。 query_cache_size:查询缓存使用的总内存空间。...生成执行计划的过程会消耗较多的时间,特别是存在许多可选的执行计划时。...如果在一条SQL语句执行过程中将该语句对应的最终执行计划进行缓存,当相似的语句再次被输入服务器时,就可以直接使用已缓存的执行计划,从而跳过SQL语句生成执行计划的整个过程,进而可以提高语句执行速度。

5.2K10

SQL】Mysql中一条sql语句执行过程

通过这张图,我们可以直观的看到MySQL的内部结构,包括连接器、缓存、解析器、优化器、存储引擎以及支持DDL、DML、存储过程、视图等功能的SQL接口。...一、SQL语句执行流程 1、连接MySQL 通常我们会编写sql语句通过某个客户端来执行并且接受执行结果,比如命令行、JDBC、navicat。...SQL解析报错 而像 select id from table1 这条sql语句会被解析成下图: 解析树 如果想了解具体的解析过程可以参考这篇博客 4、优化SQL语句 通过解析器生成sql语法树后就到了...一条查询SQL语句执行流程: 客户端通过连接器连接MySQL服务。 连接成功后向SQL接口发送SQL语句请求。...2.2 更新语句 以上就是一条查询 sql执行流程,那么接下来我们看看一条更新语句如何执行的呢?

21410

MySQL:一条SQL语句执行过程

第二步:查询缓存 当获取连接后,一条SELECT语句会先去查询缓存,看之前是否执行过。如果获取到缓存后就执行返回,不然继续后面的步骤。...第三步:分析器 分析器首先会做“词法分析”,MYSQL会识别出SQL语句里面的字符串是什么以及代表什么。接下来就是“语法分析器”,分析SQL的语法问题。...第四步:优化器 优化器会对SQL执行顺序,使用哪个索引进行优化。确定SQL执行方案。 第五步:执行执行执行SQL语句会对权限进行校验,如果有权限,就打开表继续执行。...打开表的时候,执行器就会根据表的引擎定义,去使用这个引擎提供的接口。 图片 一条update语句执行流程 update语句除了会执行上面的五步,还会涉及两个重要的日志模块。...更新语句的内部流程 update t set n = n+2 where id =1 执行器先找引擎找到id=1的那一行,如果这一行的数据页已经在内存中则直接返回给执行器。

18420

一条sql查询语句执行过程解析

因为mysql在执行过程中临时使用的内存是管理在连接对象里面的,只有在连接断开后,内存再会被释放。...好在mysql提供了“按需使用”的方式,可将参数query_cache_type设置为DEMAND,这样对于默认的sql语句就不适用查询缓存,若指定语句想使用,可用SQL_CACHE显式指定 mysql...分析器 作用:知道你要做什么 没有命中查询缓存,则开始真正执行语句了。mysql需要知道你要做什么,因此需要对sql语句做解析。...分析器 先做 词法分析 ,识别出sql语句中的字符串分别是什么,代表什么。 再做 语法分析,根据语法规则,判断sql是否满足mysql语法规则。...在数据库的慢查询日志中看到一个 rows_examined 的字段,表示这个语句执行过程中扫描了多少行。这个值就是在执行器每次调用引擎获取数据行的时候累加的。

59030

SQL语句逻辑执行过程和相关语法详解

1.1 SQL语句的逻辑处理顺序 SQL语句的逻辑处理顺序,指的是SQL语句按照一定的规则,一整条语句应该如何执行,每一个关键字、子句部分在什么时刻执行。 除了逻辑顺序,还有物理执行顺序。...物理顺序是SQL语句真正被执行时的顺序(执行计划),它是由各数据库系统的关系引擎中的语句分析器、优化器等等组件经过大量计算、分析决定的。...很多时候因为优化的关系,使得语句最终的物理执行顺序和逻辑顺序不同。按照逻辑顺序,有些应该先执行过程,可能优化器会指定它后执行。...因为DISTINCT的功能基本等价于GROUP BY,但GROUP BY却先执行。 1.12 总结 虽然SQL语句的逻辑处理过程和真正的执行计划在有些地方会有所不同。...虽然实际编写SQL语句过程中,无需去在意这其中的为什么,但我个人觉得,理解它们很有帮助,毕竟关系型数据库的本质在于关系模型和集合模型。

3.4K20

MySQL数据库:SQL语句执行过程

一、客户端的MySQL驱动: 我们的系统在和 MySQL 数据库进行通信前,需要先和数据库建立连接,而这个功能就是由MySQL驱动底层帮我们完成的,建立完连接之后,我们只需要发送 SQL 语句就可以执行...二、MySql架构的Server层: 在介绍MySQL数据库中SQL语句在Server的执行步骤前,我们先了解下MySQL的整体架构: 如果上图不清楚,可以再看看下面的图: 通过上面的架构图可以得知...在优化过程中,经过的一系列运算是什么呢?...在执行SQL语句前添加上 explain 关键字即可; 5、执行器: MySQL 通过分析器知道了你要做什么,通过优化器知道了该怎么做,于是就进入了执行器阶段,开始执行语句。...key是SQL语句,value是查询结果。我们将这个过程称为查询缓存! (2)Buffer Pool位于存储引擎层。

3.5K10

详解一条SQL语句执行过程

同时,SQL语句与数据在数据库上的存储方式无关,只是不同的数据库对于同一条SQL语句的底层实现不同罢了,但结果相同。...1,一条查询的sql语句执行的是 FROM student 负责把数据库的表文件加载到内存中去,如图1.0中所示。...4,SELECT 的执行读取规则分为sql语句中有无GROUP BY两种情况。 (1)当没有GROUP BY时,SELECT 会根据后面的字段名称对内存中的一张临时表整列读取。...(2)当查询sql中有GROUP BY时,会对内存中的若干临时表分别执行SELECT,而且只取各临时表中的第一条记录,然后再形成新的临时表。...(1.4)、图(1.5)、图(1.6),图(1.7)下面写四条"伪SQL"来说明这个查询过程

55120

SQL|语句执行逻辑

01 SQL SQL,脚本查询语言,处理代码的顺序不是按照脚本语言的顺序,这点是不同于其他编程语言的最明显特征。...SQL语言常见的比如,Mysql,HiveQL,Oracle等,虽然语法上存在一些差异,但它们在解释查询脚本上,尤其是在解析语句执行顺序上具有共性。...如果将脚本语言分解为一系列的语句,那么这些语句的先后执行顺序是怎样的呢? 这篇文章,主要总结SQL语句执行顺序。...02 Select语句执行顺序 select查询语句执行顺序,可以看出首先执行FROM子句,最后执行ORDER BY 执行顺序: (1) FROM (2) ON (3) JOIN (4) WHERE...FROM:对FROM子句中的前两个表执行笛卡尔积(交叉联接),生成虚拟表VT1,选择相对小的表做基础表。 ON:对VT1应用ON筛选器,只有那些使为真才被插入到VT2。

3.1K80

MySQL 有效利用 profile 分析 SQL 语句执行过程

在日常的工作中,我们通常要分析 SQL 语句的性能,通过会使用到执行计划,利用执行计划来分析 SQL 语句的性能,并进行相应的优化;本文将利用 profile 分析 SQL 语句执行过程来辅助的分析...SQL 语句,做好优化; 分析 SQL 执行带来的开销是优化 SQL 的重要手段。...该参数开启后,后续执行SQL 语句都将记录其资源开销,诸如 IO,上下文切换,CPU,Memory 等等。根据这些开销进一步分析当前 SQL 瓶颈从而进行优化与调整。...本文描述了如何使用 MySQL profile 以及利用 Performance_Schema 来查询 profile 的 SQL 执行过程的样例; 一、有关 profile 的描述 1、查看 profiling...query end:表示语句执行完毕了,但是还有一些后续工作没做完时的状态。

4.1K31

Mysql语句执行过程

《高性能MySQL》 衡量查询开销的三个指标 响应时间扫描的行数 服务时间(处理这条语句真正花的时间) 排队时间(等待资源,例如IO,行锁等) 扫描的行数 返回的行数 当删除了搜索条件列的索引时,语句进行全表扫描...查询的执行流程 ? 图二 语句的处理过程 1.连接数据库 客户端发起一条Query请求,监听客户端的‘连接管理模块’接收请求。 将请求转发到‘连接进/线程模块’。 调用‘用户模块’来进行授权检查。...查询优化处理(解析SQL、预处理、优化SQL执行计划),将SQL转化成一个执行计划。 解析和预处理:生成一棵解析树(《编译原理》的知识),MySQL按照其语法对解析树进行验证和解析查询。...优化过程书上介绍了很多情况,请参考书籍6.43章 执行计划 MySQL会生成一个指令树,然后通过存储引擎完成这棵树并返回结果 如图2 查询执行引擎  查询执行引擎则根据执行计划来完成整个查询。...MySQL将结果集返回给客户端是一个逐步返回的过程;数据库开始产生第一个结果时,就可以开始向服务器返回结果集。 使用MySQL客户端、服务器通信协议进行封包。 通过Tcp协议传输数据。

2.6K20

Mybatis 动态执行SQL语句

有很多的接口都只是执行SQL查询之后就直接返回给前端,那么我们能不能把这些SQL保存在数据库中,调用一个固定的接口就能根据传参查询出想要的数据呢?...调用直接传入SQL语句(可以选择存数据库)和参数,SQL语句写法和在XML内的写法保持一致即可,包括Mybatis标签等等,参数选择使用通用的Map,可以从接口接收任何参数,方法的返回值是List<Map...Configuration baseConfig = sqlSessionFactory.getConfiguration(); // 不能使用原有的config对象加载,否则下次就不会重复加载导致传入的SQL...语句不能切换 // 也可以在这里指定数据源,从对应的数据源做查询动作 Configuration configuration = new Configuration(baseConfig.getEnvironment

1.8K20
领券