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

select语句执行流程

都依赖于此时读到的权限 注意这里的权限的修改一定要使用grant语句,不要手动改表,因为grant语句可以刷新内存,权限会立即更新,但是如果手动改表,权限不会刷新内存,内存里面的权限依旧是旧的。...mysql_reset_connection是为各个编程语言提供的API,不是SQL语句。 查询缓存 MySQL获得查询请求后,会先查询缓存,如果缓存中有直接返回,否则往下执行。...分析器 MySQL Server在拿到SQL语句以后,需要知道这条语句干什么。...select id from test; 分析器做词法分析:需要把一长串字符串进行识别,比如上述语句需要将select识别出来,这是一个查询语句;test是表名,id是列名 词法分析完成以后会做语法分析...select * from test where id = 1; 假设上述表没有索引,引擎是InnoDB,执行器会这样操作: 调用InnoDB引擎接口获取表的"第一行",判断ID是否为1,如果不是则跳过

80330

select语句执行流程(MySql)

学习了极客时间MySql课程,做个总结 以一条select语句为例:select * from T where ID=4 ,梳理下执行的流程 一条sql语句执行过程中需要经过连接器、分析器、优化器、...查询缓存 在经过连接器之后,会执行第二步查询缓存,在MySql拿到查询后,会先到查询缓存查看是否执行过这条语句,之前执行的结果会以key-value对的形式存在,如果不在查询缓存中,会继续执行后面的极端...分析器 分析器会先做“词法分析”,识别出sql里的字符串分别是什么,读出“select”关键字对出这是一条查询语句,把字符串T识别成“表T” “语法分析”,根据词法分析的结果,判断该条sql是否满足MySql...的语法 优化器 优化器的作用在于选择最优的逻辑执行sql,例如在一个语句进行多表关联的时候,决定各个表的连接顺序 执行器 在开始执行前,先判断你对表T是否有执行查询的权限,没有就返回没有权限的错误,有权限则继续执行...执行器根据表的引擎定义,调用该引擎提供的接口。

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

MySQL Select语句是怎么执行的?

MySQL Select语句是怎么执行的?...今天分享的内容是select和update的执行流程。 select执行过程 话不多说,来个神图镇楼(自己画的)。...[7goo7i5di4.png] 首先,我们可以看到,整个select语句包含三个模块,其中客户端和MySQL两个部分,MySQL又包含server端和存储引擎侧,server端包含连接器、查询缓存...这里可以给出一个例子,例如我们建立了(a,b)的联合索引, select * from table where a=1 and b=1; select * from table where b=1 and...A1:有些时候,SQL语句要操作的表不只是SQL字面上那些。比如如果有个触发器,得在执行器阶段(过程中)才能确定。优化器阶段前是无能为力的 Q2:MySQL权限到底在哪里验证?

2.3K40

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

1.2 查询缓存 连接建立以后可以执行 select 语句了。这就会来到第二步:查询缓存。 查询缓存中存储的数据是 key-value 的形式,key 是查询语句,value 是查询的结果。...逻辑是这样的:先看看查询缓存有没该语句对应的 value?有则直接取出返回客户端,无则继续到数据库执行语句。查出结果后会放一份到缓存中,再返回客户端。...首先根据 "select" 识别出这是查询语句。字符串 "user" 识别成 "表名 user"、字符串 "id" 识别成 "列名 id"。...MySQL 是个聪明的仔,再执行之前会自己优化下客户端传过来的语句,看看那种执行起来不那么占内存、快一点。...比如下面的 sql 语句select * from user u inner join role r on u.id = r.user_id where u.name = "狗哥" and r.id

2.1K20

灵魂拷问,SQL 查询语句执行 SELECT吗?

好了,不调侃了,我们先来看下SELECT语句的完整语法: 1. SELECT 2. DISTINCT 3. FROM 4...._2; 的结果一致,都是表示求笛卡尔积;用于直接计算两个表笛卡尔积,得到虚拟表VT1,这是所有select语句最先执行的操作,其他操作是在这个表上进行的,也就是from操作所完成的内容 on: 从VT1...,(不能使用聚合函数)得到VT4表; group by: 对VT4表进行分组,得到VT5表;其后处理的语句,如select,having,所用到的列必须包含在group by条件中,没有出现的需要用聚合函数...(不行,窗口函数是 SELECT 语句里,而 SELECT 是在 WHERE 和 GROUP BY 之后) 可以基于 GROUP BY 里的东西进行 ORDER BY 吗?...从这个语句来看,好像 GROUP BY 是在 SELECT 之后执行的,因为它引用了 SELECT 中的一个别名。

1.1K30

SQL 查询语句总是先执行 SELECT?你们都错了

SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。 ?...(不行,窗口函数是 SELECT 语句里,而 SELECT 是在 WHERE 和 GROUP BY 之后) 可以基于 GROUP BY 里的东西进行 ORDER BY 吗?...所以: 如果你想要知道一个查询语句是否合法,或者想要知道一个查询语句会返回什么,可以参考这张图; 在涉及查询性能或者与索引有关的东西时,这张图就不适用了。...混合因素:列别名 有很多 SQL 实现允许你使用这样的语法: SELECT CONCAT(first_name, \' \', last_name) AS full_name, count(*) 从这个语句来看...,好像 GROUP BY 是在 SELECT 之后执行的,因为它引用了 SELECT 中的一个别名。

1.3K10

select top语句 mysql_SQL SELECT TOP 语句

SELECT TOP 子句用于规定要返回的记录的数目。 SELECT TOP 子句对于拥有数千条记录的大型表来说,是非常有用的。 注释:并非所有的数据库系统都支持 SELECT TOP 子句。...SQL SELECT TOP 是等价的 MySQL 语法 SELECT column_name(s) FROM table_name LIMIT number; 实例 SELECT * FROM Persons...LIMIT 5; Oracle 语法 SELECT column_name(s) FROM table_name WHERE ROWNUM <= number; 实例 SELECT * FROM Persons...TOP 实例 下面的 SQL 语句从 “Customers” 表中选取头两条记录: SELECT TOP 2 * FROM Customers; SQL SELECT TOP PERCENT 实例 下面的...SQL 语句从 “Customers” 表中选取前面 50% 的记录: SELECT TOP 50 PERCENT * FROM Customers; 发布者:全栈程序员栈长,转载请注明出处:https

1.9K20

SQL 查询语句总是先执行 SELECT?你们都错了

1 SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。...(不行,窗口函数是 SELECT 语句里,而 SELECT 是在 WHERE 和 GROUP BY 之后) 可以基于 GROUP BY 里的东西进行 ORDER BY 吗?...所以: 如果你想要知道一个查询语句是否合法,或者想要知道一个查询语句会返回什么,可以参考这张图; 在涉及查询性能或者与索引有关的东西时,这张图就不适用了。...tableGROUP BY full_name 从这个语句来看,好像 GROUP BY 是在 SELECT 之后执行的,因为它引用了 SELECT 中的一个别名。...数据库引擎还会做一系列检查,确保 SELECT 和 GROUP BY 中的东西是有效的,所以会在生成执行计划之前对查询做一次整体检查。

1.2K20

SQL 查询语句总是先执行 SELECT?你们都错了

SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。 ?...(不行,窗口函数是 SELECT 语句里,而 SELECT 是在 WHERE 和 GROUP BY 之后) 可以基于 GROUP BY 里的东西进行 ORDER BY 吗?...所以: 如果你想要知道一个查询语句是否合法,或者想要知道一个查询语句会返回什么,可以参考这张图; 在涉及查询性能或者与索引有关的东西时,这张图就不适用了。...table GROUP BY full_name 从这个语句来看,好像 GROUP BY 是在 SELECT 之后执行的,因为它引用了 SELECT 中的一个别名。...数据库引擎还会做一系列检查,确保 SELECT 和 GROUP BY 中的东西是有效的,所以会在生成执行计划之前对查询做一次整体检查。

1.2K20

SQL 查询语句总是先执行 SELECT?你们都错了

1 SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。 ?...(不行,窗口函数是 SELECT 语句里,而 SELECT 是在 WHERE 和 GROUP BY 之后) 可以基于 GROUP BY 里的东西进行 ORDER BY 吗?...所以: 如果你想要知道一个查询语句是否合法,或者想要知道一个查询语句会返回什么,可以参考这张图; 在涉及查询性能或者与索引有关的东西时,这张图就不适用了。...table GROUP BY full_name 从这个语句来看,好像 GROUP BY 是在 SELECT 之后执行的,因为它引用了 SELECT 中的一个别名。...数据库引擎还会做一系列检查,确保 SELECT 和 GROUP BY 中的东西是有效的,所以会在生成执行计划之前对查询做一次整体检查。

1.4K40

详解一条查询select语句和更新update语句执行流程

前言 一条select语句执行流程 建立连接 查询缓存 解析器和预处理器 词法解析和语法解析(Parser) 预处理器(Preprocessor) 查询优化器(Query Optimizer) 优化器可以做哪些优化...前面几篇MySQL系列的文章介绍了索引,事务和锁相关知识,那么今天就让我们来看看当我们执行一条select语句和一条update语句的时候,MySQL要经过哪些步骤,才能返回我们想要的数据。...一条select语句执行流程 MySQL从大方向来说,可以分为 Server 层和存储引擎层。...SHOW VARIABLES LIKE 'optimizer_trace'; set optimizer_trace='enabled=on'; 接下来执行一句查询语句SELECT t1.name...总结 本文主要分析了select和update语句执行过程,而在分析update语句执行过程中,又简单介绍了redo log和bin log相关概念,这一部分内容在本文中没有过多深入的讲解,仅仅只是为了让大家去理解更新流程而做了简单的介绍

2K20

SQL 查询语句执行 SELECT?兄弟你认真的么?

言归正传,SELECT语句的完整语法如下: 1. SELECT 2. DISTINCT 3. FROM 4...._2; 的结果一致,都是表示求笛卡尔积;用于直接计算两个表笛卡尔积,得到虚拟表VT1,这是所有select语句最先执行的操作,其他操作时在这个表上进行的,也就是from操作所完成的内容 on: 从VT1...,(不能使用聚合函数)得到VT4表; group by: 对VT4表进行分组,得到VT5表;其后处理的语句,如select,having,所用到的列必须包含在group by条件中,没有出现的需要用聚合函数...(不行,窗口函数是 SELECT 语句里,而 SELECT 是在 WHERE 和 GROUP BY 之后) 可以基于 GROUP BY 里的东西进行 ORDER BY 吗?...从这个语句来看,好像 GROUP BY 是在 SELECT 之后执行的,因为它引用了 SELECT 中的一个别名。

1.3K20

SQL 查询总是先执行SELECT语句吗?你们都错了!

SQL 查询的执行顺序 于是我研究了一下,发现顺序大概是这样的。SELECT 并不是最先执行的,而是在第五个。 ?...(不行,窗口函数是 SELECT 语句里,而 SELECT 是在 WHERE 和 GROUP BY 之后) 可以基于 GROUP BY 里的东西进行 ORDER BY 吗?...所以: 如果你想要知道一个查询语句是否合法,或者想要知道一个查询语句会返回什么,可以参考这张图; 在涉及查询性能或者与索引有关的东西时,这张图就不适用了。...table GROUP BY full_name 从这个语句来看,好像 GROUP BY 是在 SELECT 之后执行的,因为它引用了 SELECT 中的一个别名。...数据库引擎还会做一系列检查,确保 SELECT 和 GROUP BY 中的东西是有效的,所以会在生成执行计划之前对查询做一次整体检查。

93820

select语句做了什么?

今天陈某透过一个简单的查询语句来讲述在Mysql内部的执行过程。...这时候如果你要继续,就需要重连,然后再执行请求了。 2. 查询缓存【废材,8.0 版本完全删除】 连接建立完成后,你就可以select语句了,执行之前会查询缓存。...分析器 如果没有命中查询缓存,就要执行查询了,但是在执行查询之前,需要对SQL语句做解析,判断你这条语句有没有语法错误。...MYSQL会从你输入的select 这个关键字识别出来是一个查询语句,table是表名,id是列名。...优化器的作用一句话总结:根据MYSQL内部的算法决定如何执行这条SQL语句来达到MYSQL认为代价最小目的。 优化器阶段完成后,这个语句执行方案就确定了,接下来就交给执行执行了。 5.

10520
领券