• 子查询详解


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

  • 相关阅读:
    Spider 爬虫
    python 数据分析几个重要点!!!
    python 接口开发<小demo>
    python 运维那些事儿~ <转>
    centos7 Docker 安装 (转)
    centos7+nginx+uwsgi+python3+django
    linux 用户组 文件权限
    Linux 进阶命令(二)转
    centos7 vi命令
    基于UDP协议的socket套接字编程
  • 原文地址:https://www.cnblogs.com/jiang-Xin/p/5430308.html
Copyright © 2020-2023  润新知