接下来我们来说明上文的 SQL 语句到底在内部经历了什么。 连接器 第一步,客户端会先连接到数据库,这个时候就是连接器来接待。它负责跟客户端建立连接、获取权限、维持和管理连接。...修改完成后,只有再重新建立的连接才会使用到新的权限设置。 建立连接的过程通常是比较复杂的,所以我建议你在使用中要尽量减少建立连接的动作,也就是尽量使用长连接。...优化器 经过了分析器分析,MySQL 知道你要干啥了,在开始执行之前,还要先经过优化器的处理。...优化器的作用就是它认为的最优的执行方案去执行(虽然有时候也不是最优),比如多个索引的时候该如何选择索引,多表查询的时候如何选择关联顺序等。...InnoDB 引擎把数据保存在内存中,同时记录 redo log,此时 redo log 进入 prepare 状态,然后告诉执行器,执行完成了,随时可以提交。
LIKE模糊查询userName包含A字母的数据(%A%) SQL: SELECT * FROM UserInfo WHERE userName LIKE "%A%" MongoDB: db.UserInfo.find...({userName :/A/}) LIKE模糊查询userName以字母A开头的数据(A%) SQL: SELECT * FROM UserInfo WHERE userName LIKE "A%"
前两天发了一条SQL慢的原因有哪些,在那篇文章我没有说到优化器之类的,我觉得如果配合一条SQL是如何执行的,会更好,所以特地找了一篇。...来源:JavaGuide | 作者:木木匠 本篇文章会分析一个 sql 语句在 MySQL 中的执行流程,包括 sql 的查询在 MySQL 内部会怎么流转,sql 语句的更新是怎么完成的。...一 MySQL 基础架构分析 1.1 MySQL 基本架构概览 下图是 MySQL 的一个简要架构图,从下图你可以很清晰的看到用户的 SQL 语句在 MySQL 内部是如何执行的。...MySQL 查询不建议使用缓存,因为查询缓存失效在实际业务场景中可能会非常频繁,假如你对一个表更新的话,这个表上的所有的查询缓存都会被清空。对于不经常更新的数据来说,使用缓存还是可以的。...2.2 更新语句 以上就是一条查询 sql 的执行流程,那么接下来我们看看一条更新语句如何执行的呢?
点击关注"故里学Java" 右上角"设为星标"好文章不错过 前边的在《一条SQL查询在MySQL中是怎么执行的》中我们已经介绍了执行过程中涉及的处理模块,包括连接器、分析器、优化器、执行器、存储引擎等。...今天我们来一起看看一条更新语句又是怎么一个执行流程。 查询语句的一套执行流程,更新语句也会同样的走一步,下边我们在对照上次文章中的图来简单的看一下: ?...首先,在执行语句前要先连接数据库,这是第一步中连接器的工作,前面我们也说过,当一个表有更新的时候,跟这个表有关的查询缓存都会失效,所以我们一般不建议使用查询缓存。...> update table demo set c = c + 1 where ID = 2; 接下来我们来看看update语句的执行流程,图中浅色框表示在存储引擎中执行的,深色框代表的是执行器中执行的...binlog来恢复数据的时候,就会多了一个事务出来,执行这条更新语句,将值从0更新成1,与原库中的0就不同了。
主要负责用户登录数据库,进行用户的身份认证,包括校验账户密码,权限等操作,如果用户账户密码已通过,连接器会到权限表中查询该用户的所有权限,之后在这个连接里的权限逻辑判断都是会依赖此时读取到的权限数据,也就是说...连接建立后,执行查询语句的时候,会先查询缓存,MySQL 会先校验这个 sql 是否执行过,以 Key-Value 的形式缓存在内存中,Key 是查询预计,Value 是结果集。...当然在真正执行缓存查询的时候还是会校验用户的权限,是否有该表的查询条件。 ...MySQL 查询不建议使用缓存,因为查询缓存失效在实际业务场景中可能会非常频繁,假如你对一个表更新的话,这个表上的所有的查询缓存都会被清空。...对于不经常更新的数据来说,使用缓存还是可以的。 所以,一般在大多数情况下我们都是不推荐去使用查询缓存的。
来源:http://t.cn/E6U9Z9T ---- 概览 本篇文章会分析下一个sql语句在mysql中的执行流程,包括sql的查询在mysql内部会怎么流转,sql语句的更新是怎么完成的。...第二步,语法分析,主要就是判断你输入的sql是否正确,是否符合mysql的语法。 完成这2步之后,mysql就准备开始执行了,但是如何执行,怎么执行是最好的结果呢?这个时候就需要优化器上场了。...二、语句分析 2.1 查询语句 说了以上这么多,那么究竟一条sql语句是如何执行的呢?其实我们的sql可以分为2中,一种是查询,一种是更新(增加,更新,删除)。...: 先检查该语句是否有权限,如果没有权限,直接返回错误信息,如果有权限,在mysql8.0版本以前,会先查询缓存,以这条sql语句为key在内存中查询是否有结果,如果有直接缓存,如果没有,执行下一步。...进行权限校验,如果没有权限就会返回错误信息,如果有权限就会调用数据库引擎接口,返回引擎的执行结果。 2.2 更新语句 以上就是一条查询sql的执行流程,那么接下来我们看看一条更新语句如何执行的呢?
数据库的服务端,可分为执行器(Execution Engine) 和 存储引擎(Storage Engine) 两部分: 执行器负责解析SQL执行查询 存储引擎负责保存数据 1 SQL如何在执行器中执行...不同DB不同优化方法,优化总体思路:在执行计划中,尽早减少须处理的数据量。即尽量在执行计划最内层减少要处理的数据量。...到这,执行器只在逻辑层分析SQL,优化查询执行逻辑,执行计划中操作的数据,仍是表、行和列。在数据库中,表、行、列都是逻辑概念,所以,这个执行计划叫“逻辑执行计划”。...执行查询接下来的部分,涉及数据库的物理存储结构。 2 SQL是如何在存储引擎中执行 数据真正存储时,无论在磁盘or内存中,都没法直接存储这种带行列的二维表。...在InnoDB中,表的索引也是以B+树的方式来存储的,和存储数据的B+树的区别是,在索引树中,叶子节点保存的不是行数据,而是行的主键值。
SQL是如何在执行器中执行的 ? 我们通过一个例子来看一下,执行器是如何来解析执行一条 SQL 的。...但是,按照上面那个执行计划,需要执行 2 个全表扫描,然后再把 2 个表的所有数据做一个 JOIN 操作,这个性能是非常非常差的。 优化的总体思路是,在执行计划中,尽早地减少必须处理的数据量。...到这里,执行器只是在逻辑层面分析 SQL,优化查询的执行逻辑,我们执行计划中操作的数据,仍然是表、行和列。在数据库中,表、行、列都是逻辑概念,所以,这个执行计划叫“逻辑执行计划”。...执行查询接下来的部分,就需要涉及到数据库的物理存储结构了。 SQL是如何存在存储引擎中执行的? 数据真正存储的时候,无论在磁盘里,还是在内存中,都没法直接存储这种带有行列的二维表。...在 InnoDB 中,表的索引也是以 B+ 树的方式来存储的,和存储数据的 B+ 树的区别是,在索引树中,叶子节点保存的不是行数据,而是行的主键值。
SQL是如何在执行器中执行的 ? 我们通过一个例子来看一下,执行器是如何来解析执行一条 SQL 的。...但是,按照上面那个执行计划,需要执行 2 个全表扫描,然后再把 2 个表的所有数据做一个 JOIN 操作,这个性能是非常非常差的。 优化的总体思路是,在执行计划中,尽早地减少必须处理的数据量。...到这里,执行器只是在逻辑层面分析 SQL,优化查询的执行逻辑,我们执行计划中操作的数据,仍然是表、行和列。在数据库中,表、行、列都是逻辑概念,所以,这个执行计划叫“逻辑执行计划”。...执行查询接下来的部分,就需要涉及到数据库的物理存储结构了。 SQL是如何存在存储引擎中执行的? 数据真正存储的时候,无论在磁盘里,还是在内存中,都没法直接存储这种带有行列的二维表。...比如,上面的订单表组织成 B+ 树,是这个样的: 在 InnoDB 中,表的索引也是以 B+ 树的方式来存储的,和存储数据的 B+ 树的区别是,在索引树中,叶子节点保存的不是行数据,而是行的主键值。
♣ 题目部分 在Oracle中,如何获取SQL历史执行计划?...♣ 答案部分 历史执行计划只能从AWR中获取,如果AWR没有记录的话,那么就无法获取历史执行计划了,获取历史执行计划的命令如下所示: SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY_AWR...(L_DBID => , L_INST_NUM => , L_BID => , L_EID => , L_SQLID => )) ; 其中,L_DBID代表数据库的DBID,L_INST_NUM代表数据库的实例号...,单机环境为1,RAC环境填写具体的实例号,L_BID为开始的快照号,L_EID为结束的快照号,L_SQLID为要查看SQL的SQL_ID。...下面的例子可以直接从AWR中获取SQL_ID为“bsa0wjtftg3uw”的执行计划,可以看到历史有2种执行计划,一个是全表扫描,一个是索引范围扫描: SYS@RAC2LHR1> SELECT * FROM
♣ 题目部分 在Oracle中,如何查到会话正在执行的SQL语句?...通过SQL_ID这个字段,可以获取到某个会话正在执行的SQL语句。...SQL_ID VARCHAR2(13) 正在执行的SQL语句ID SQL_CHILD_NUMBER NUMBER 正在执行的SQL语句的子游标的ID,从0开始 SQL_EXEC_START DATE 该会话开始执行该...SQL语句的时间。...若SQL_ID为空,则该列为空。 SQL_EXEC_ID NUMBER SQL执行的标识符ID。若SQL_ID为空或SQL还未开始执行,则该列为空。
♣ 题目部分 在Oracle中,如何在不执行SQL的情况下获取执行计划? ♣ 答案部分 1、“EXPLAIN PLAN FOR SQL”不实际执行SQL语句,生成的计划未必是真实执行的计划。...但是,必须要有PLAN_TABLE表,可以执行脚本“@?/rdbms/admin/utlxplan.sql”来创建。...2、SQL*Plus的AUTOTRACE功能,命令:SET AUTOTRACE TRACEONLY EXPLAIN。...除SET AUTOTRACE TRACEONLY EXPLAIN外其它的AUTOTRACE方式均实际执行SQL。...但是,如果该命令后执行的是DML语句,那么该DML语句是确实被Oracle实际执行过的。 本文选自《Oracle程序员面试笔试宝典》,作者:李华荣。
♣ 题目部分 在Oracle中,如何得到已执行的目标SQL中的绑定变量的值?...♣ 答案部分 当Oracle解析和执行含有绑定变量的目标SQL时,如果满足如下两个条件之一,那么该SQL中的绑定变量的具体输入值就会被Oracle捕获: l 当含有绑定变量的目标SQL以硬解析的方式被执行时...l 当含有绑定变量的目标SQL以软解析或软软解析的方式重复执行时,Oracle在默认情况下至少得间隔15分钟才会捕获一次。...查询视图V$SQL_BIND_CAPTURE或V$SQL可以得到已执行目标SQL中绑定变量的具体输入值。...如果V$SQL_BIND_CAPTURE中查不到,那么有可能对应的Shared Cursor已经从Shared Pool中被清除了,这时候可以尝试从AWR相关的数据字典表DBA_HIST_SQLSTAT
平时我们使用的数据库,看到的通常是一个整体,比如我们执行一条查询SQL,返回一个结果集,却不知道这条语句在MySQL内部是如何执行的,接下来我们就来简单的拆解一下MySQL,看看MySQL是由哪些“零件...这样在我们以后遇到MySQL的一些异常或者问题的时候,就可以快速定位问题并解决问题。 下边通过一张图来看一下SQL的执行流程,从中可以清楚的看到SQL语句在MySQL的各个功能模块中执行的过程。 ?...如果查询语句在缓存中可以查到这个key,就直接把结果返回给客户端。如果语句不在缓存中,就会继续执行后边的阶段。执行完成后,将执行结果存入缓存中。...优化器遵循的原则:尽可能扫描少的数据库行记录。 优化器阶段完成后,这个SQL语句的执行方案就确定下来了,进入执行阶段。...在数据库的慢查询日志中可以看到一个rows_examined的字段,表示这个语句执行过程中扫描了多少行,这个值是在执行器每次调用引擎的时候累加的,有时候执行器调用一次,在引擎内部扫描了多行,隐藏引擎扫描行数跟
从以下地址下载emoji的utf8编码文件 https://gist.github.com/JoshyPHP/225b3c77005a89d81511 2. ...查询测试 -- 源数据 SELECT x.content FROM x WHERE CommentID in (39539523,39205786); -- 关联查询 SELECT distinct...x.content FROM x, emoji_utf8 WHERE CommentID in (39539523,39205786) and x.content like concat('%',c...,'%'); 加distinct是因为存在同一表情符号对应两个utf8编码的情况,如0xE29C8C和0xE29C8CEFB88F。
【SQL】在一个含有group by的查询sql中,同时存在having和where,sql在解析执行的时候,先执行的是哪一个?...where 执行顺序:from,where,group by,having,select,order by 执行顺序:FROM>ON>JOIN>WHERE>GROUP BY>WITH CUBE or...WITH ROLLUP>HAVING>SELECT>DISTINCT>ORDER BY>TOP where过滤from所指定的数据源,但对于group by所产生的分组无效; having过滤分组,它依附于
从以下地址复制emoji的unicode https://unicode.org/emoji/charts/full-emoji-list.html 2....查询测试 -- 源数据 SELECT x.content FROM x WHERE CommentID in (39539523,39205786); -- 关联查询 SELECT distinct...x.content FROM x, emoji_unicode WHERE CommentID in (39539523,39205786) and x.content like '%'||e||...'%'; 结果如下: 字典表关联一个四千二百万行的评论表,其中评论字段 content 数据类型为 varchar(6000),查询出所有带 emoji 的评论,用时25分钟。
♣ 题目部分 在Oracle中,SQL语句的执行过程有哪些? ♣ 答案部分 Oracle数据库里SQL语句的执行过程可以如下图所示: ?...在查询转换过程中,Oracle会根据一些规则来决定是否对目标SQL执行查询转换,这些规则在Oracle不同的版本里不尽相同。...在Oracle 9i中,查询转换是独立于优化器的,它与优化器的类型无关,但是从Oracle 10g开始,Oracle会对某些类型的查询转换(比如子查询展开、复杂视图合并等)分别计算经过查询转换后的等价改写...只有当等价改写后SQL的成本值小于未经过查询转换的原始SQL的成本值时,Oracle才会对目标SQL执行查询转换。在执行完查询转换后,原目标SQL可能就被Oracle改写了,当然也有可能没有改写。...(5)在得到了目标SQL的执行计划后,接下来Oracle就会根据执行计划去实际执行该SQL,并将执行结果返回给用户。 本文选自《Oracle程序员面试笔试宝典》,作者:李华荣。
♣ 题目部分 在Oracle中,如何从执行计划初步判断SQL的性能问题?...l 递归调用(recursive calls)值是否过大 l 表的访问次数是否过大 l 注意表真实访问行数 l 查看是否在磁盘排序 l 注意A-Time时间列 l 注意Pstart、Pstop、PARTITION...RANGE ALL l 注意MERGE JOIN CARTESIAN l 注意REMOTE分布式查询 l 注意动态采样 l 是否使用了某种固定执行计划的策略 详情可以从下表所示的几个方面去考虑: ?...此外,还有一些其它需要注意的地方,例如COST花费特别大的步骤、全表扫描的步骤、FILTER的操作等等,都是需要特别关注的地方,这里就不详细列举了,总之,看执行计划和看AWR报告一样,需要具有一双敏锐的鹰眼...,最主要的是找出SQL的性能瓶颈。
我们知道,通过Delete From [xxx] where a=x 可以删除数据,那么如何删除通过查询出来的数据呢?...示例 w3resources - SQL Delete records using subqueries DELETE FROM customer1 WHERE agent_code=ANY( SELECT...agent_code FROM agents WHERE working_area='London'); 那么我们如何删除通过查询发现对比两个查询中的不一致的呢?...FROM Original EXCEPT SELECT CustId, CustName, CustAddress, CustPhone FROM Revised 所以当我们想要删除通过查询对比出不一致的数据...,应该 ELETE FROM customer1 WHERE agent_code=ANY( Select UserID From Original Where UserID not like '[
领取专属 10元无门槛券
手把手带您无忧上云