子查询详解

概要:sql server 子查询分为相关子查询和非相关子查询(又叫嵌套子查询或独立子查询),(最简单的区分相关/嵌套子查询的方法就是单独执行子查询,可以成功执行的就是嵌套子查询)。

嵌套子查询的执行不依赖与外部的查询。执行过程:

(1)执行子查询,其结果不被显示,而是传递给外部查询,作为外部查询的条件使用。

(2)执行外部查询,并显示整个结果。

嵌套子查询一般可以分为:返回单值的子查询 和 返回一个列表(多值)的子查询 

返回单值一般用 = ,<>, >=, <=, >, < 等等, 返回多值用 IN, ANY, ALL

相关子查询的执行依赖于外部查询,一般是在where子句中引用外部的表。执行过程如下:

(1)从外层查询中取出一个元组,将元组相关列的值传给内层查询。

(2)执行内层查询,得到子查询操作的值。

(3)外查询根据子查询返回的结果或结果集得到满足条件的行。

(4)然后外层查询取出下一个元组重复做步骤1-3,直到外层的元组全部处理完毕。 

EXISTS关键字:

相关子查询中经常用到EXISTS关键字,很多情况下是可以用IN关键字加嵌套子查询来代替的。如下两个查询时等价的

select * from A where id in (select id from B);

select * from A where exists (select 1 from B where A.id=B.id);

区别在于in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询。但是效率就要视情况而定了, 通常认为当A表较大B表较小时用IN, 反之用EXISTS。

原文地址:https://www.cnblogs.com/jiang-Xin/p/5430308.html