zoukankan      html  css  js  c++  java
  • 子查询详解

    概要: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。

  • 相关阅读:
    问题 F: A+B和C (15)
    问题 E: Shortest Distance (20)
    完数
    分解质因数
    念整数
    问题 B: 习题7-7 复制字符串中的元音字母
    问题 A: 习题7-5 字符串逆序存放
    问题 D: 习题6-12 解密
    计算机的重点编码方式
    PyCharm更换第三方包源
  • 原文地址:https://www.cnblogs.com/jiang-Xin/p/5430308.html
Copyright © 2011-2022 走看看