* FROM Person_Visison WHERE Person_Visison.Pid=Person.id) '); 不相关子查询:子查询的查询条件不依赖于父查询的称为不相关子查询。...相关子查询:子查询的查询条件依赖于外层父查询的某个属性值的称为相关子查询,带EXISTS 的子查询就是相关子查询。...相关子查询执行过程:先在外层查询中取“学生表”的第一行记录,用该记录的相关的属性值(在内层WHERE子句中给定的)处理内层查询,若外层的WHERE子句返回“TRUE”值,则这条记录放入结果表中。...然后再取下一行记录;重复上述过程直到外层表的记录全部遍历一次为止。 Exists:若子查询的结果集非空时,返回“True”;若子查询的结果集为空时,返回“False” 。...NOT EXISTS :若子查询结果为空,返回“TRUE”值;若子查询的结果集非空时,返回 “FALSE。 嘿嘿嘿好理解多了吧!!!!!!!
而优化所使用的策略正是本节要讨论的重点内容,而且优化部分也是整个查询引擎的难点。 子链接(SubLink)如何优化?子查询(SubQuery)又如何处理?对表达式(Expression)如何进行优化?...(2)当语句为非工具语句时,PostgreSQL使用pg_plan_queries对语句进行优化。...tuple_fraction描述我们期望获取的元组的比例,0代表我们需要获取所有的元组;当tuple_faction Î(0,1)时,表明我们需要从满足条件的元组中取出tuple_faction这么多比例的元组...;当tuple_factionÎ [1,+¥ )时,表明我们将按照所指定的元组数进行检索,例如,LIMIT语句中所指定的元组数。...和HAVING子句中的条件合并,如果存在能合并的HAVING子句则将其合并到WHERE条件中,否则保留在HAVING子句中; 消除外连接(Outer Join)中的冗余部分,reduce_outer_joins
大家好,又见面了,我是你们的朋友全栈君。 1.简介 不相关子查询:子查询的查询条件不依赖于父查询的称为不相关子查询。...相关子查询:子查询的查询条件依赖于外层父查询的某个属性值的称为相关子查询,带EXISTS 的子查询就是相关子查询 EXISTS表示存在量词:带有EXISTS的子查询不返回任何记录的数据,只返回逻辑值“True...); 相关子查询执行过程:先在外层查询中取“学生表”的第一行记录,用该记录的相关的属性值(在内层WHERE子句中给定的)处理内层查询,若外层的WHERE子句返回“TRUE”值,则这条记录放入结果表中。...Exists:若子查询的结果集非空时,返回“True”;若子查询的结果集为空时,返回“False” 。...NOT EXISTS :若子查询结果为空,返回“TRUE”值;若子查询的结果集非空时,返回 “FALSE。
大家好,又见面了,我是你们的朋友全栈君。 1、简介 不相关子查询:子查询的查询条件不依赖于父查询的称为不相关子查询 相关子查询:子查询的查询条件依赖于外层父查询的某个属性值的称为相关子查询。...='C1') 相关子查询执行过程:先在外层查询中取“学生表”的第一行记录,利用该记录的相关属性值(在exists子查询的where子句中用到的列)处理内层查询,若外层的where子句返回“true”,则本条记录放入结果表中...Exists(select):若子查询的结果集非空时,exists()表达式返回true;子查询的结果集为空时,exists()表达式返回false。...C1 内层的not exists()值为true,说明选课表中找不到“S1.StudentNo + C1.CourseNo”这一记录,说明学生S1没有选课程C1,此时内层查询的返回结果集会加上C1,当内层查询的返回结果集不为空时...C2,当内层查询的返回结果集为空时,外层not exists()值为true,则外层where子句值为true,则S1被选中。
一、嵌套查询概念 在sql语言中,一个select-from-where语句成为一个查询块,将一个查询块嵌套在另一个查询块的where子句或having短语的条件中的查询成为嵌套查询。...嵌套查询分类: 1、相关子查询/关联子查询:子查询的查询条件依赖于父查询,比如,如果子查询需要执行多次,即采用循环的方式,先从外部查询开始,每次都传入子查询进行查询,然后再将结果反馈给外部,这种嵌套的执行方式就称为关联子查询...2、不相关子查询/非相关子查询:子查询的查询条件不依赖于父查询,比如:子查询从数据表中查询了数据结果,这个数据结果只执行一次,然后这个数据结果作为主查询的条件进行执行,这样的子查询叫做非关联子查询。...带有in谓词的子查询 用在where子句中用来判断查询的属性是否在多个值的列表中。...exists后,若子查询结果为空,则外层的where子句返回真值,否则返回假值。
3.2 多关系查询 我们可以在where子句中指定匹配条件,然后进行多关系查询。...事实上查询时,select,from,where子句并不是顺序执行的。正确的理解如下。 1.为from所列出的关系产生笛卡尔积。 2.在1的结果上应用where子句中指定的谓词。...8.3 空关系测试 SQL中包含一个特性,测试一个子查询的结果是否存在元组,exist结构在作为参数的子查询非空时返回true值。...在包含了子查询的查询中,在相关名称上可以应用作用域规则,根据此规则,在一个子查询中只能使用此子查询本身定义的,或者包含此子查询的任何查询中定义的相关名称,如果一个相关名称既在子查询中局部定义,有在包含该子查询的查询中全局定义...8.5 from子句中的子查询 前面的子查询都是在where子句中使用的,下面介绍在from子句中使用子查询。
EXPLAIN为SELECT语句中使用的每个表返回一行信息,它按照MySQL在处理语句时读取表的顺序列出输出中的表。...上面我们说过id也会为空,就是在使用union进行查询的时候。...在解释id的例子中有。 SUBQUERY:不会被查询优化器优化的子查询中,不依赖于外部查询的结果集,第一个 SELECT 关键字代表的那个查询的 select_type 就是 SUBQUERY。...MATERIALIZED:当查询优化器在执行包含子查询的语句时,选择将子查询物化之后与外层查询进行连接查询时,该子查询对应的 select_type 属性就是 MATERIALIZED。...,在 Extra 列中会显示Using where;当使用索引访问来执行对某个表的查询,并且该语句的 WHERE 子句中有除了该索引包含的列之外的其他搜索条件时,在 Extra 列中也会显示Using
SUBQUERY(subquery):子查询中的第一个SELECT,结果不依赖于外部查询。...DEPENDENT SUBQUERY(dependent subquery):子查询中的第一个SELECT,依赖于外部查询。...我们在进行条件查询时,建议使用索引,否则将引起全表扫描,IO的开销和程序的性能都没法保证!...这是const联接类型的一个特例。当MySQL对查询某部分进行优化,并转换为一个常量时,使用这些类型( system/const )访问。...如将主键置于where列表中,MySQL就能将该查询转换为一个常量。当查询的表只有一行的情况下,使用system。 const:表最多有一个匹配行,它将在查询开始时被读取。
ref:Join 语句中被驱动表索引引用查询,这个连接类型只有在查询使用了不是惟一或主键的键或者是这些类型的部分(比如,利用最左边前缀)时发生。对于之前的表的每一个行联合,全部记录都将从表中读出。...如果为空,没有可能的索引,可以为相关的域从WHERE语句中选择一个合适的语句 4、key 实际使用的索引。如果为NULL,则没有使用索引。很少的情况下,MYSQL会选择优化不足的索引。...:除子查询或者UNION 之外的其他查询; SUBQUERY:子查询内层查询的第一个SELECT,结果不依赖于外部查询结果集; UNCACHEABLE SUBQUERY:结果集无法缓存的子查询;UNION...:UNION 语句中第二个SELECT 开始的后面所有SELECT,第一个SELECT 为PRIMARYUNION RESULT:UNION 中的合并结果; 8、Extra 关于MYSQL如何解析查询的额外信息...看到这个的时候,查询就需要优化了。mysql需要进行额外的步骤来发现如何对返回的行排序。它根据连接类型以及存储排序键值和匹配条件的全部行的行指针来排序全部行。
SUBQUERY 子查询的第一个select(不依赖外部查询) DEPENDENT SUBQUERY 依赖于外部查询的子查询 ... IN 子查询的查询语句中,如果查询优化器决定将 IN 子查询转换为 EXISTS 子查询,而且子查询可以使用到主键进行等值匹配的话,那么该子查询执行计划的 type 列的值就是 unique_subquery...= 1) No matching min/max row 当查询列表处有 MIN 或者 MAX 聚集函数,但是并没有符合 WHERE 子句中的搜索条件的记录时,将会提示该额外信息...,并且该语句的 WHERE 子句中有针对该表的搜索条件时,在Extra 列中会提示上述额外信息。... IN 子查询转换成 semi-join ,而 semi-join 又 有好多种执行策略,当执行策略为 DuplicateWeedout 时,也就是通过建立临时表来实现为外层查中的记录进行去重操作时,驱动表查询执行计划的
专栏持续更新中:MySQL详解 在日常工作中,我们会有时会开慢查询去记录一些执行时间比较久的SQL语句,找出这些SQL语句并不意味着完事了,些时我们常常用到explain这个命令来查看一个这些SQL...filtered 按表条件过滤的行百分比 Extra 执行情况的描述和说明 下面对这些字段出现的可能进行解释: 一、 id SELECT识别符。...语句中第二个select开始后面所有select) SUBQUERY(子查询中的第一个SELECT,结果不依赖于外部查询) DEPENDENT SUBQUERY(子查询中的第一个SELECT,依赖于外部查询...system: 当MySQL对查询某部分进行优化,并转换为一个常量时,使用这些类型访问。...如将主键置于where列表中,MySQL就能将该查询转换为一个常量,system是const类型的特例,当查询的表只有一行的情况下,使用system NULL: MySQL在优化过程中分解语句,执行时甚至不用访问表或索引
在由语法树到查询树的转换过程中,查询引擎会将查询语句中的某些部分进行转换。...在查询引擎语法树到查询树转换后,PostgreSQL查询引擎会使用pg_rewrite中设定的转换规则进行所谓的基于规则的转换,例如,PostgreSQL查询引擎会将VIEW进行转换,为后续的优化提供可能...-工具类语句 当查询语句为工具类查询(Utility Statements)语句时,查询引擎将经过词法分析和语法分析后获得的查询语句作为其执行计划。...当查询语句中涉及的基表数量较小时,由于其对应的最优解(最优查询访问路径)搜索空间较小,PostgreSQL将采用动态规划算法(Dynamic Programming)来求解最优查询访问路径;但当查询中涉及的基表数量较多时...那些pull_up函数和约束条件的处理又是如何完成的呢?是否所有的子链接和子查询都可以进行转换?两个基表构成连接所需要满足什么样的条件呢?
UNION RESULT:UNION 的结果(如果是 UNION ALL 则无此结果) ? SUBQUERY:子查询中的第一个 SELECT 查询,不依赖于外部查询的结果集 ? ...DEPENDENT SUBQUERY:子查询中的第一个select查询,依赖于外部查询的结果集 ? DERIVED:派生表(临时表),常见于 FROM 子句中有子查询的情况 ? ...大多数情况下用不到分区,所以这一列我们无需关注 type 关联类型或者访问类型,它指明了 MySQL 决定如何查找表中符合条件的行,这是我们判断查询是否高效的重要依据(type 之于 EXPLAIN...访问方式,unique_subquery 是针对在一些包含 IN 子查询的查询语句中,如果查询优化器决定将 IN 子查询转换为 EXISTS 子查询,而且子查询可以使用到主键或者唯一索引进行等值匹配时...using where 表示存储引擎搜到记录后进行了后过滤(POST-FILTER),如果查询未能使用索引,using where 的作用只是提醒我们 mysql 要用 where 条件过滤结果集
MySQL会在查询上设置一个标记。当执行查询时,这个标记会使其返回关于在执行计划中每一步的信息,而不是真正完全的执行该语句。 它会返回一行或多行信息,显示出执行计划中的每一部分和执行的次序。...在查询中,每个表的输出只有一行,若多表关联,则输出多行。别名表单算为一个表,因此如果把表和自己连接,输出中也会有两行。这里的表的定义非常的广:可以是一个子查询,一个 UNION 结果。...其他部分标记如下: SUBQUERY,包含在SELECT子句(不在from子句中)中的子查询的SELECT,结果不依赖于外部查询。 DERIVED,包含在from子句中的子查询中的SELECT。...当from字句中有子查询的时候,table列是的形式,N指向子查询id,这里N总是指向EXPLAIN输出结果中的后面的一行。...const,system:当MySQL能对查询的某部分进行优化并将其转换成一个常量时,它就会使用这些访问类型。
创建示例数据库 在我们开始在SQL中进行查询之前,我们将首先创建一个数据库和几个表,然后使用一些示例数据填充这些表。这将使您在以后开始查询时获得一些实践经验。...一个WHERE条款一般语法如下: . . . WHERE column_name comparison_operator value WHERE子句中的比较运算符定义应如何将指定列与值进行比较。...请注意,当使用UNION从多个表查询多个列时,每个SELECT语句必须查询相同数量的列,相应的列必须具有相似的数据类型,并且每个SELECT语句中的列必须具有相同的顺序。...查询多个表的另一种方法是使用子查询。子查询(也称为内部或嵌套查询)是包含在另一个查询中的查询。这些在您尝试根据单独的聚合函数的结果过滤查询结果的情况下非常有用。...但是,有些情况下,外部查询必须首先读取表中的每一行,并将这些值与子查询返回的数据进行比较,以便返回所需的数据。在这种情况下,子查询称为相关子查询。 以下语句是相关子查询的示例。
EXPLAIN为用于SELECT语句中的每个表返回一行信息。 ...select 查询,不依赖于外部查询的结果集 DEPENDENT UNION,UNION 中的第二个或随后的 select 查询,依赖于外部查询的结果集 SUBQUERY,子查询中的第一个...select 查询,不依赖于外部查询的结果集 DEPENDENT SUBQUERY,子查询中的第一个 select 查询,依赖于外部查询的结果集 DERIVED,用于 from子句里有子查询的情况...MySQL会递归执行这些子查询, 把结果放在临时表里。 UNCACHEABLE SUBQUERY,结果集不能被缓存的子查询,必须重新为外层查询的每一行进行评估。...eq_ref,查询条件为等于 ref,条件查询不等于 ref_or_null,同ref(条件查询),包含NULL值的行。
UNION UNION 中的第二个或随后的 select查询,不依赖于外部查询的结果集。 DEPENDENT UNION UNION中的第二个或随后的 select查询,依 赖于外部查询的结果集。...SUBQUERY 子查询中的第一个select查询,不依赖于外部查询的结果集。 DEPENDENT SUBQUERY 子查询中的第一个select查询,依赖于外部查询的结果集。...DERIVED 用于from子句里有子查询的情况。MySQL会递归执行这些子查询,把结果放在临时表里。...UNCACHEABLE SUBQUERY 结果集不能被缓存的子查询,必须重新为外层查询的每一行进行评估。...当查询的表仅有一行时,使用System。 ref 连接不能基于关键字选择单个行,可能查找到多个符合条件的行。叫做ref是因为索引要跟某个参考值相比较。
SUBQUERY SUBQUERY即子查询,子查询也是一个普通查询,目的是将用子查询返回的数据将被用来在主查询中作为条件,以进一步限制要检索的数据。...子查询只能有一个在SELECT子句中的列,除非多列在主查询的查询来比较其选定的列。 ORDER BY不能使用在子查询中,虽然主查询就可以使用ORDER BY。...GROUP BY可以用来执行相同的功能在子查询中的ORDER BY。 子查询返回多于一行只能用于使用多值的运算符,如为IN,EXISTS,IN,ANY / SOME,ALL运算符。...使用示例如下: -- SELECT语句中的子查询 SELECT * FROM COMPANY WHERE ID IN (SELECT ID FROM COMPANY WHERE SALARY > 45000...EXISTS内部有一个子查询语句(SELECT … FROM…),我将其称为EXIST的内查询语句。其内查询语句返回一个结果集。EXISTS子句根据其内查询语句的结果集空或者非空,返回一个布尔值。
子查询的优化 当一个查询是另一个查询的子部分时,称之为子查询(查询语句中嵌套有查询语句) 查询的子部分,包括哪些情况: 1目标列位置。...FROM子句中,数据库可能返回类似“在FROM子句中的子查询无法参考相同查询级别中的关系”的提示,所以相关子查询不能出现在FROM子句中; 非相关子查询出现在FROM子句中,可上拉子查询到父层,在多表连接时统一考虑连接代价然后择优...示例: 3 WHERE子句位置 出现在WHERE子句中的子查询,是一个条件表达式的一部分,而表达式可以分解为操作符和操作数;根据参与运算的不同的数据类型,操作符也不尽相同,如INT类型有“、=...子查询因依赖于父查询的参数,当父查询的参数改变时,子查询需要根据新参数值重新执行(查询优化器对相关子查询进行优化有一定意义),如: 2 非相关子查询 子查询的执行,不依赖于外层父查询的任何属性值。...子查询中的连接条件、过滤条件分别变成了父查询的连接条件、过滤条件,优化器可以对这些条件进行下推,以提高执行效率。 How to optimize SubQuery?
ref:Join 语句中被驱动表索引引用查询,这个连接类型只有在查询使用了不是惟一或主键的键或者是这些类型的部分(比如,利用最左边前缀)时发生。对于之前的表的每一个行联合,全部记录都将从表中读出。...如果为空,没有可能的索引,可以为相关的域从WHERE语句中选择一个合适的语句 key_len 表示索引中使用的字节数,可通过该列计算查询中使用的索引的长度(key_len显示的值为索引字段的最大可能长度...UNION:子查询中的UNION,且为UNION 中从第二个SELECT 开始的后面所有SELECT,同样依赖于外部查询的结果集; PRIMARY:子查询中的最外层查询,注意并不是主键查询; SIMPLE...:除子查询或者UNION 之外的其他查询; ** SUBQUERY**:子查询内层查询的第一个SELECT,结果不依赖于外部查询结果集; ** UNCACHEABLE SUBQUERY**:结果集无法缓存的子查询...看到这个的时候,查询就需要优化了。mysql需要进行额外的步骤来发现如何对返回的行排序。它根据连接类型以及存储排序键值和匹配条件的全部行的行指针来排序全部行。
领取专属 10元无门槛券
手把手带您无忧上云