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