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中的一个,不然报错

 

 

 

 

 

 

 

 

  

 

posted @ 2017-03-10 12:15  雷雨天的雷胖子  阅读(366)  评论(0编辑  收藏  举报