子查询详解
概要: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。