• sql server 子查询


    子查询(subquery)定义

      --子查询是SQL Server支持的T-SQL语言特性之一,可以内嵌在一个select、insert、update或delete语句中
      --T-SQL子查询可以放在SQL语句中任何一个允许使用表达式的地方.例如,你可以在一个select语句的select列表中内嵌一个子查询,或者在where子句中包含一个子查询作为一个查询条件。
      --当把T-SQL子查询内嵌到SQL语句的时,必须用括号把它括起来,此外,子查询不能包含在compute或者for browse子句,而且也不能包含在order by子句,除非在select子句中使用了top运算符
      --有时,子查询又被称为内部选择或内部查询。嵌入子查询的语句被称为外部选择或外部查询
      --SQLServer子查询可以分为相关子查询嵌套子查询两类


    嵌套子查询
      --嵌套子查询的执行不依赖与外部的查询
      执行过程:
              --执行子查询,其结果不被显示,而是传递给外部查询,作为外部查询的条件使用
              --执行外部查询,并显示整个结果

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

    返回单值

      --SElECT *
        FROM table_name_0
        WHERE column_name_0>
        (
        SELECT AVG(column_name_1)
        FROM table_name_1
        )
        GO

    返回值列表

      --SElECT *
        FROM table_name_0
        WHERE column_name_0 IN
        (
        SELECT column_name_1
        FROM table_name_1
        )
        GO


    相关子查询

      --相关子查询的执行依赖于外部查询。多数情况下是子查询的where子句中引用了外部查询的表

      执行过程:

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

             --执行内层查询,得到子查询操作的值

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

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

      示例:

      --查询Booka表中大于该类图书价格平均值的图书信息?

          SElECT 图书名
          FROM Books As a
          WHERE 价格 >
          (
          SELECT AVG(价格)
          FROM Books AS b
          WHERE a.类编号=b.类编号
           )
          GO

      --与前面介绍过的子查询不同,相关子查询无法独立于外部查询而得到解决。该子查询需要一个“类编号”的值。而这个值是个变量,随SQLSever检索Books表中的不同行而改变。下面详细说明该查询执行过程:

      --先将Books表中的第一条记录的“类编号”的值“2”代入子查询中,子查询变为:

          SELECT AVG(价格)
              FROM Books AS b
             WHERE b.类编号=2

      --子查询的结果为该类图书的平均价格,所以外部查询变为:

          SElECT 图书名,出版社,类编号,价格
             FROM Books As a
           WHERE 价格 > 34

      --如果WHERE条件为True,则第一条结果包括在结果集中,则否不包括。对Books表中的所有行运行相同的过程,最后形成的结果集及最后返回结果。


    常见问题

          SELECT
           * 
          FROM
          (
           SELECT
           *
           FROM
           TB_RT_BSQDATA a
          ) GO| as column_name

      --子查询()后面必须加上go或者as column_name中的一个,不然报错

     

     

     

     

     

     

      

     

    要么生,要么死
  • 相关阅读:
    浅谈localStorage和sessionStorage的相关用法
    v-for中:key的作用总结
    textarea的placeholder无效问题解决
    6月10日
    6月9日
    6月8日
    6月7日
    6月6日
    10月5日
    6月4日
  • 原文地址:https://www.cnblogs.com/llljpf/p/6530020.html
Copyright © 2020-2023  润新知