[SQL SERVER系列]之嵌套子查询和相关子查询
子查询有两种类型,一种是只返回一个单值的子查询,这时它可以用在一个单值可以使用的地方,这时子查询可以看作是一个拥有返回值的函数;另外一种是返回一列值的子查询,这时子查询可以看作是一个在内存中临时存在的数据表。
1.嵌套子查询
嵌套子查询的执行不依赖于外部的查询。执行过程:
)执行子查询,其结果不被显示,而是传递给外部查询,作为外部查询的条件使用。
)执行外部查询,并显示整个结果。
嵌套子查询一般可以分为:返回单值的子查询 和 返回一个列表的子查询。
--返回单值的子查询
SElECT 图书名,作者,出版社,价格 FROM Books
WHERE 价格 >
(
SELECT AVG(价格) FROM Books
)
--返回列表的子查询
SElECT * FROM Readers
WHERE 读者编号 IN
( SELECT 读者编号 FROM [Borrow History] )
2.相关子查询
相关子查询的执行依赖于外部查询。多数情况下是子查询的WHERE子句中引用了外部查询的表。执行过程:
)从外层查询中取出一个元组,将元组相关列的值传给内层查询。
)执行内层查询,得到子查询操作的值。
)外查询根据子查询返回的结果或结果集得到满足条件的行。
)然后外层查询取出下一个元组重复做步骤1-3,直到外层的元组全部处理完毕。
--查询Books表中大于该类图书价格平均值的图书信息
SElECT 图书名,出版社,类编号,价格 FROM Books As a WHERE 价格 > ( SELECT AVG(价格) FROM Books AS b WHERE a.类编号=b.类编号 )
使用SQL跨表批量导入数据时实用的例子
利用相关子查询只插入test2中不存在的记录,避免因插入重复记录而失败
insert into test2(userid, username)
select userid, username from test1
where not exists(
select userid from test2 where
test2.userid = test1.userid
)
EXISTS 就是用来测试子查询的结果是否为空,如果结果集为空则匹配结果为 false,否则匹配结果为 true。
--如果存在山东省的读者,将T_Book表中所有记录查询出来;否则,查询结果为空
SELECT * FROM T_Book WHERE EXISTS (SELECT * FROM T_Reader WHERE FProvince='ShanDong' )
--查询某一类图书的分类id,最小最大出版年份,数量
select C.FId,
MIN(B.FYearPublished) as minpublished,
MAX(B.FYearPublished) as maxpublished,
COUNT(0) as Number
from T_Category C inner join T_Book B
ON C.FId = B.FCategoryId
group by C.FId
--查询某一类图书的分类id,图书的名称,最早出版年份
select T_Category.FId, T_Book.FName, T_Book.FYearPublished from
T_Category inner join T_Book
ON T_Category.FId = T_Book.FCategoryId
WHERE T_Book.FYearPublished = (
select MIN(T_Book.FYearPublished) from
T_Book WHERE T_Book.FCategoryId = T_Category.FId
)
3.WITH和子查询
SQL提供了WITH子句用于为子查询定义一个别名,这样就可以通过这个别名来引用这个子查询了,也就是实现“一次定义多次使用”。
WITH子句的格式为: WITH 别名 AS (子查询)
WITH person_tom AS (
SELECT * FROM T_Person WHERE FName='TOM'
)
SELECT * FROM T_Person WHERE FAge=person_tom.FAge OR FSalary=person_tom.FSalary
参考文献:
1.程序员的sql金典
2.http://www.cnblogs.com/Ryan_j/archive/2010/10/20/1857026.html
如果您有什么问题,欢迎在下面评论,我们一起讨论,谢谢~
如果您觉得还不错,不妨点下右下方的推荐,有您的鼓励我会继续努力的~
[SQL SERVER系列]之嵌套子查询和相关子查询的更多相关文章
- Sql Server系列:嵌套查询
嵌套查询是指一个查询语句嵌套在另一个查询语句内部的查询.嵌套查询也就子查询,在SELECT子句中先计算子查询,子查询结果作为外层另一个查询的过滤条件,查询可以基于一个表或多个表.子查询中可以使用比较运 ...
- ylb:子查询(嵌套子查询)和子查询(相关子查询)
ylbtech-SQL Server:SQL Server-子查询(嵌套子查询)和子查询(相关子查询) SQL Server 子查询(嵌套子查询)和子查询(相关子查询). 1,ylb:1,子查询(嵌套 ...
- SQL嵌套子查询和相关子查询的执行过程有什么区别(推荐)
SQLServer子查询可以分为 相关子查询 和 嵌套子查询 两类.前提, 假设Books表如下: 类编号 图书名 出版社 价格 ----------------------------------- ...
- sql之独立子查询和相关子查询总结
1.独立子查询:顾名思义:就是子查询和外层查询不存在任何联系,是独立于外层查询的: 下面就看一个例子: 有一张订单表 Sales.Order 和一张 客户表 Sales.Customer 下面的sql ...
- Sql Server系列:子查询
1 子查询概念 子查询是嵌套在另一个查询中的普通T-SQL查询.在有一个SELECT语句通过使用小括号创建子查询,作为另一个查询的部分数据或条件的基础. 子查询通常用于满足以下某个需求: ◊ 将一个查 ...
- SQL相关子查询是什么?和嵌套子查询有什么区别?
目录 两者的各种叫法 相关子查询MySQL解释 相关子查询Wikipedia解释 相关子查询执行步骤拆解 相关子查询和嵌套查询的区别 参考资料 两者的各种叫法 相关子查询叫做:Correlated S ...
- 相关子查询【SQL Server】
查询book表中大于该类图书价格平均值的图书信息 先将第一条记录的类编号的值为2代入子查询中,子查询为 select avg(price) from book b where b.id=2 则得到类编 ...
- sql 相关子查询
子查询:嵌套在其他查询中的查询. 子查询有称内部查询,而包含子查询的语句称之为外部查询 所有的子查询可以分两类,既 相关子查询和非相关子查询 1>非相关子查询是独立于外部查询的子查询,子查询总共 ...
- T-SQL的进阶:超越基本级别3:构建相关子查询——701小组
T-SQL的进阶:超越基本级别3:构建相关子查询 格雷戈里·拉森,2014/03/05 原文链接: http://www.sqlservercentral.com/articles/Stairway+ ...
随机推荐
- 逆向+两次bfs(UVA 1599)
为什么都说简单好想咧.坦白从宽看了人家的代码,涨了好多姿势,, http://blog.csdn.net/u013382399/article/details/38227917 被一个细节坑了.. 2 ...
- Java事件总线
在平时写代码的过程中,我们需要实现这样一种功能:当执行某个逻辑时,希望能够进行其他逻辑的处理.最粗暴的方法是直接依赖其他模块,调用该模块的相应函数或者方法.但是,这样做带来一些问题. 模块间相互依赖, ...
- 在Android中动画移动一个View的位置,采用Scroller类实现Android动画之 View移动
在Android中动画移动一个View的位置,采用Scroller类实现 今天说最近自己遇到的一个问题,就是要用动画效果来移动一个VIew的位置. 这个具体的情况是,需要做一个SlidingMenu的 ...
- 【转】APP测试要点
APP测试的时候,建议让开发打好包APK和IPA安装包,测试人员自己安装应用,进行测试.在测试过程中需要注意的测试点如下: 1.安装和卸载 ●应用是否可以在IOS不同系统版本或android不同系统版 ...
- Linux 命令 - mv: 移动或重命名文件
命令格式 cp [OPTION]... [-T] SOURCE DEST cp [OPTION]... SOURCE... DIRECTORY cp [OPTION]... -t DIRECTORY ...
- Linux 命令 - crontab: 任务调度
cron 是一个 Linux 下的定时执行工具,可以在无需人工干预的情况下运行作业.守护进程 cron 会读取 crontab 文件,根据配置在指定的时间执行任务.contab 命令用来添加.删除.显 ...
- C#中显/隐式实现接口及其访问方法
原贴地址: http://www.cnblogs.com/dudu837/archive/2009/12/07/1618663.html 在实现接口的时候,VS提供了两个菜单,一个是"实现接 ...
- uml与数据库设计
一.类之间的关系如下图所示: 二.UML与数据库设计主要讨论的内容: 三.依赖关系强调的是类操作间的使用关系,类图到表结构的映射中并不涉及这种关系,所以只需讨论泛化关系.关联关系到表的映身规范. 1. ...
- selenium Grid(一)
selenium grid Quick Start selenium-grid是用于设计帮助我们进行分布式测试的工具,其整个结构是由一个hub节点和若干个代理节点组成.hub用来管理各个代理节点的注册 ...
- PHP学习笔记 - 进阶篇(1)
PHP学习笔记 - 进阶篇(1) 数组 数组定义 $arr = array();表示创建一个空数组,并把创建的空数组赋值给变量$arr. 索引数组初始化 PHP有两种数组:索引数组.关联数组. 索引和 ...