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

一条查询SQL在MySQL中是怎么执行的

平时我们使用的数据库,看到的通常是一个整体,比如我们执行一条查询SQL,返回一个结果集,却不知道这条语句在MySQL内部是如何执行的,接下来我们就来简单的拆解一下MySQL,看看MySQL是由哪些“零件...这样在我们以后遇到MySQL的一些异常或者问题的时候,就可以快速定位问题并解决问题。 下边通过一张图来看一下SQL的执行流程,从中可以清楚的看到SQL语句在MySQL的各个功能模块中执行的过程。 ?...MySQL拿到一个查询请求后,会先到缓存查查看看,如果之前执行过的语句就会将执行过的语句和结果以key-value对的形式,被直接存放在内存中,key是查询语句,value是结果。...如果查询语句在缓存中可以查到这个key,就直接把结果返回给客户端。如果语句不在缓存中,就会继续执行后边的阶段。执行完成后,将执行结果存入缓存中。...在数据库的慢查询日志中可以看到一个rows_examined的字段,表示这个语句执行过程中扫描了多少行,这个值是在执行器每次调用引擎的时候累加的,有时候执行器调用一次,在引擎内部扫描了多行,隐藏引擎扫描行数跟

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

    在 SQL 中,如何使用子查询来获取满足特定条件的数据?

    在 SQL 中,可以使用子查询来获取满足特定条件的数据。子查询是嵌套在主查询中的查询语句,它返回一个结果集,可以用来过滤主查询的结果。...下面是使用子查询来获取满足特定条件的数据的一般步骤: 在主查询中使用子查询,将子查询的结果作为条件。 子查询可以在主查询中的 WHERE 子句、FROM 子句或 HAVING 子句中使用。...子查询可以返回单个值或多个值,具体取决于使用的运算符和子查询的语法。 以下是一些示例: 使用子查询在 WHERE 子句中过滤数据: SELECT column1, column2, ......FROM (SELECT column FROM table WHERE condition) AS temp_table; 使用子查询在 HAVING 子句中过滤数据: SELECT column1,...FROM table GROUP BY column1 HAVING column1 > (SELECT AVG(column1) FROM table); 请注意,子查询的性能可能会较低,因此在设计查询时应谨慎使用

    24110

    mybatis如何直接 执行传入的任意sql语句 并按照顺序取出查询的结果集 mybatis如何直接 执行传入的任意sql语句 并按照顺序取出查询的结果集

    mybatis如何直接 执行传入的任意sql语句 并按照顺序取出查询的结果集 需求: 1.直接执行前端传来的任何sql语句,parameterType="String", 2.对于任何sql语句,其返回值类型无法用...resultMap在xml文件里配置或者返回具体的bean类型,因此设置resultType="java.util.Map",但是Map并不保证存入取出顺序一致, 因此设置resultType="java.util.LinkedHashMap...",为保证查询的字段值有序(存入与取出顺序一致)所以采用LinkedHashMap。...3.当返回值为LinkedHashMap时,表中存储的null值并不会存入Map中,因此还要在mybatis配置文件中增加如下配置: ${sql} 这样配置时,会出现:there no getter sql in java.lang.String 的异常,因此sql改成value,便不会报错。

    3K20

    PostgreSQL查询当前执行中SQL的执行计划——pg_show_plans

    generic plan是指对于preapre语句生成计划,该计划策略会在执行execute语句的时候把参数bind到plan中,然后执行计划。...但是explain查询当前缓存的执行计划,在实际中估算的成本可能是不准确的,因为很可能估算的成本和实际运行的成本不一致。...pg_show_plans模块 接下来的主题则是一个供PostgreSQL数据库查询正在进行的SQL执行计划的模块——pg_show_plans,它可以动态查找当前正在进行的SQL执行计划。...一个session执行一条较慢SQL(便于获取到其执行计划) 一个session在SQL执行过程获取其执行计划 2.这里我举例的SQL为对一张346MB的表的全表扫描。...通过pg_show_plans和pg_stat_activity联合查询出当前正在进行的SQL执行计划。

    2.9K40

    InnoDB在SQL查询中的关键功能和优化策略

    前言通过上篇文章《MySQL的体系结构与SQL的执行流程》了解了SQL语句的执行流程以及MySQL体系结构中「连接器」、「SQL接口」、「解析器」、「优化器」、「执行器」的功能以及在整个流程中的作用。...不过上篇文章留了个尾巴,在执行器调用存储引擎后,存储引擎内部做了什么事没有进一步说明,本文会对此展开介绍,使得我们对SQL整体的执行流程有更加清晰的认识。...在MySQL的体系结构中,存储引擎是负责和磁盘交互的,当执行一条SQL语句,最终是通过存储引擎获取结果,不论是查询语句、插入语句还是更新语句,所以存储引擎是用来查询、存储、管理数据的。...很显然,当InnoDB收到一个查询SQL的请求后会有两个操作:先去内存中查找有没有符合条件的数据,有,直接将数据返回给执行器。...如果内存中符合条件的数据,此时需要去磁盘中查找并加载到内存,然后将数据返回给执行器。没错,在查询数据时InnoDB干的活就是这么简单。当然,我们还是要深入内部了解一下原理。

    62475

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

    提出问题: 对于一个做后台不久的我,起初做项目只是实现了功能,所谓的增删改查,和基本查询索引的建立。直到有一个面试官问我一个问题,一条sql查询语句在mysql数据库中具体是怎么执行的?...本篇文章通过 一条sql查询语句在mysql数据库中具体是怎么执行的? 来具体讲解mysql的基础架构。...Mysql确定了查询语句,会先到查询缓存中,看之前是否执行过这条查询语句。之前如果执行过这条查询语句,查询结果可能会以key-value的方式直接缓存在内存中。...key是查询的语句,value是查询到的值,这样的话查询缓存会直接把value值返回给客户端。查询语句如果步子查询缓存中,会正常往下执行,获取到新的查询结果后会被存入到查询缓存中。...开始执行的时候,要先判断一下你对这个表 Student 有没有执行查询的权限,如果没有,就会返回没有权限的错误,如下所示 (在工程实现上,如果命中查询缓存,会在查询缓存返回结果的时候,做权限验证。

    5.6K20

    sql 在not in 子查询有null值情况下经常出现的陷阱

    如果下:Table_A表和Table_B表,要求查询出在Table_A表中不在Table_B表中的记录。 CREATE TABLE [dbo]....dbo.Table_A AS a WHERE a.ID NOT IN ( SELECT b.ID FROM dbo.Table_B AS b) 然而查询出来并没有达到预期的...ID    Name 001  张三        003  王五           原因很简单:由于NULL不能进行如何的“操作” –如果null参与算术运算,则该算术表达式的值为null。...(例如:+,-,*,/ 加减乘除) –如果null参与比较运算,则结果可视为false。(例如:>=,  大于,小于,不等于) –如果null参与聚集运算,则聚集函数都置为null。...--如果在not in子查询中有null值的时候,则不会返回数据。

    2.6K10

    同样的SQL语句在查询分析器执行很快,但是网站上执行超时的诡异问题

    同样的SQL语句在查询分析器执行很快,但是网站上执行超时,这个问题以前遇到过,解决办法是重新启动服务器,但过一段时间后(时间长短不一定,一般为一天后),这次又出现了,不能总是重新启动服务器了事吧...查阅资料得知,SQL SERVER 会把所有带参数化查询的SQL语句使用sp_executesql来执行,因为它能够分析并缓存查询计划,从而优化查询效率,这也是为什么通常说的“参数化查询比拼接SQL要快...将上面的SQL语句再拿到查询分析器里面执行,速度很快,不到1秒就出来了,将它再拿到另外一个.NET写的数据库查询工具程序中执行,却报出了跟网站一样的错误:查询超时!    ...ADO.net可能因为这个警告导致出结果很慢,虽然在sql server里执行没什么问题。 原因是sum里面没有isnull一下。改了一下sql语句就好了。...(补充: 执行procedure过程,出现“警告:聚合或其它   SET   操作消除了空值”警告 会导致存储过程的结果集无法得到。

    2.5K70

    sql查询结果和预想的不一样?多半是null在作怪

    不知道兄弟们是否有同感 在写查询语句的时候我们通常不会刻意去考虑表中的”null“值 但有些时候对比查询结果和数据库又发现跟预想的不一样!...函数来解决这个问题 修改之后的SQL: SELECT IFNULL(SUM(mark),0) FROM test 返回了期望的查询结果: 02null导致count函数遗漏统计数目 如果我们以某个可以为...我们的表中是存在一条数据的,所以正常的返回结果应该是1, 但由于mark为null,所以就被遗漏了,返回了0。...修改之后的SQL: SELECT COUNT(*) FROM test 返回了期望的查询结果: 03判断null要用"is null",而非"= null" 如果我们的查询条件中涉及null判断,使用...这是显然不正确的,所以我们应该用”is null“这种写法 修改之后的SQL: SELECT * FROM test WHERE mark is null 返回了期望的查询结果: - THE END

    1.2K20

    mysql,SQL标准,多表查询中内连接,外连接,自然连接等详解之查询结果集的笛卡尔积的演化

    它实际返回连接表中所有数据行的笛卡尔积,其结果集合中的数据行数等于第一个表中符合查询条件的数据行乘以第二个表中符合查询条件的数据行数,即10X11=110条记录。...而后执行where子句,在中间表中,搜索S2中成绩低于60的学生的记录,同时要求记录中S1与S2是同一个学生的记录即学号相同。最后执行select语句,从中间表获取S1中相应的信息作为结果表。...简单来说,中间表是没有重复记录的,但是S1部分字段是有重复的,而结果集提取的只是S1部分的字段,因此就有可能有重复记录。 一般情况,自连接也可以使用子查询的方式实现。...缺点是,虽然可以指定查询结果包括哪些列,但是不能人为地指定哪些列被匹配。另外,自然连接的一个特点是连接后的结果表中匹配的列只有一个。如上,在自然连接后的表中只有一列C。...外连接 不管是内连接还是带where子句的多表查询,都组合自多个表,并生成结果表。换句话说,如果任何一个源表中的行在另一个源表中没有匹配,DBMS将把该行放在最后的结果表中。

    2.5K20

    SQL优化之一则MySQL中的DELETE、UPDATE 子查询的锁机制失效案例

    对大表或高并发的表的执行 DELETE、UPDATE 子查询操作,甚至可能导致业务长时间不可用。 MySQL 下的 InnoDB 行锁,是通过以位图方式对 index page 加锁机制来实现的。...update 子查询,优化器先执行了 id 为2的 (DEPENDENT SUBQUERY )相关子查询部分,然后通过对 PRIMARY 以索引全扫描方式对全表 155041 行数据加锁主锁,来执行的...,inner join 联表的情况下,只对需更新的数据行加索,并发性能最高;exitsts 子查询在 delete 与 update 操作下,均为全索引扫描,并发最差;in 子查询在 update 操作下与...PRIMARY 索引全扫描的方式,锁住了表中数据行,阻碍了对表的 delete,update 操作,却不妨碍 insert 的并发操作,MySQL 5.6 之后的优化器对 not in 子查询做了相关优化工作...MySQL 优化器以及 InnoDB 行锁机制特性,增加了 UPDATE、DELETE 下子查询复杂的度,在 MySQL 数据库程序开发数据库维护过程中,真正了解优化器的实现和 InnoDB 行锁机制的行为

    2.4K40

    【YashanDB知识库】decode函数中的子查询被不必要地多次执行

    问题现象客户向yashandb下发的SQL语句执行时间超过6分钟仍未出结果问题的风险及影响SQL语句性能慢,影响客户业务问题影响的版本所有的yashandb 22.2版本23.2版本没有这个问题问题发生原因...decode函数在执行时判断有误,即使没有匹配到这个分支,这个分支中的子查询依然会被执行解决方法及规避方式规避方式:将decode改写为case when问题分析和处理过程通过分析如下ddl及最后sql...dual connect by rownum 子查询b中有4条记录,分别为1 2 3 4,decode中只会匹配1,所以decode中对a表的全表扫描只有一次。...所以,正常情况下,整个select语句会有1000多的一致读。但是如果yashandb存在decode函数的执行问题,也就是异常情况,整个select语句会有4000多的一致读。...正常情况下的截图:异常情况下的截图:经验总结使用statistics_level=all及autotrace来分析sql语句的一致读数量,进而推断性能表现。

    2000

    MyBatis源码 | 一条查询单条结果(`select * from t_user where id = ?`)SQL的执行方法链追踪流程

    环境:mybatis版本3.4.5 mysql数据库驱动版本:5.1.6 MyBatis源码: 一条查询单条结果(select * from t_user where id = ?)...SQL的执行方法链追踪流程 sqlSession.getMapper得到的mapper就是动态代理对象,是MapperProxy类型: UserDao mapper = sqlSession.getMapper...开始跟踪,以下是层层深入,查看该执行流程的方法调用链,里面涉及到的设计模式有:动态代理、装饰者模式、责任链模式(XXXHandler类里面)、命令模式; 底层是调用了JDBC的执行代码,我们可以追踪到connection...#prepare >org.apache.ibatis.executor.statement.PreparedStatementHandler#query >java.sql.PreparedStatement...#execute 该方法是JDBC的,可以执行任意SQL语句 >org.apache.ibatis.executor.resultset.DefaultResultSetHandler

    51110
    领券