子查询有两种类型,一种是只返回一个单值的子查询,这时它可以用在一个单值可以使用的地方,这时子查询可以看作是一个拥有返回值的函数;另外一种是返回一列值的子查询,这时子查询可以看作是一个在内存中临时存在的数据表。

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系列]之嵌套子查询和相关子查询的更多相关文章

  1. Sql Server系列:嵌套查询

    嵌套查询是指一个查询语句嵌套在另一个查询语句内部的查询.嵌套查询也就子查询,在SELECT子句中先计算子查询,子查询结果作为外层另一个查询的过滤条件,查询可以基于一个表或多个表.子查询中可以使用比较运 ...

  2. ylb:子查询(嵌套子查询)和子查询(相关子查询)

    ylbtech-SQL Server:SQL Server-子查询(嵌套子查询)和子查询(相关子查询) SQL Server 子查询(嵌套子查询)和子查询(相关子查询). 1,ylb:1,子查询(嵌套 ...

  3. SQL嵌套子查询和相关子查询的执行过程有什么区别(推荐)

    SQLServer子查询可以分为 相关子查询 和 嵌套子查询 两类.前提, 假设Books表如下: 类编号 图书名 出版社 价格 ----------------------------------- ...

  4. sql之独立子查询和相关子查询总结

    1.独立子查询:顾名思义:就是子查询和外层查询不存在任何联系,是独立于外层查询的: 下面就看一个例子: 有一张订单表 Sales.Order 和一张 客户表 Sales.Customer 下面的sql ...

  5. Sql Server系列:子查询

    1 子查询概念 子查询是嵌套在另一个查询中的普通T-SQL查询.在有一个SELECT语句通过使用小括号创建子查询,作为另一个查询的部分数据或条件的基础. 子查询通常用于满足以下某个需求: ◊ 将一个查 ...

  6. SQL相关子查询是什么?和嵌套子查询有什么区别?

    目录 两者的各种叫法 相关子查询MySQL解释 相关子查询Wikipedia解释 相关子查询执行步骤拆解 相关子查询和嵌套查询的区别 参考资料 两者的各种叫法 相关子查询叫做:Correlated S ...

  7. 相关子查询【SQL Server】

    查询book表中大于该类图书价格平均值的图书信息 先将第一条记录的类编号的值为2代入子查询中,子查询为 select avg(price) from book b where b.id=2 则得到类编 ...

  8. sql 相关子查询

    子查询:嵌套在其他查询中的查询. 子查询有称内部查询,而包含子查询的语句称之为外部查询 所有的子查询可以分两类,既 相关子查询和非相关子查询 1>非相关子查询是独立于外部查询的子查询,子查询总共 ...

  9. T-SQL的进阶:超越基本级别3:构建相关子查询——701小组

    T-SQL的进阶:超越基本级别3:构建相关子查询 格雷戈里·拉森,2014/03/05 原文链接: http://www.sqlservercentral.com/articles/Stairway+ ...

随机推荐

  1. hihocoder 1038 01背包

    #1038 : 01背包 时间限制:20000ms 单点时限:1000ms 内存限制:256MB 描述 且说上一周的故事里,小Hi和小Ho费劲心思终于拿到了茫茫多的奖券!而现在,终于到了小Ho领取奖励 ...

  2. SignalR 2.0 系列:SignalR的服务器广播

    英文渣水平,大伙凑合着看吧…… 这是微软官方SignalR 2.0教程Getting Started with ASP.NET SignalR 2.0系列的翻译,这里是第八篇:SignalR的服务器广 ...

  3. Android重力感应开发

    http://blog.csdn.net/mad1989/article/details/20848181 一.手机中常用的传感器 在Android2.3 gingerbread系统中,google提 ...

  4. (转)java:快速文件分割及合并

    文件分割与合并是一个常见需求,比如:上传大文件时,可以先分割成小块,传到服务器后,再进行合并.很多高大上的分布式文件系统(比如:google的GFS.taobao的TFS)里,也是按block为单位, ...

  5. js中元素操作的有关内容与对比

    以下 A:代表原生js B:代表jQuery 1 创建元素/节点 A: 元素节点- createElement( ) 文本节点 - createTextNode() 例如: var a = docum ...

  6. lucene4入门(2)搜索

    欢迎转载http://www.cnblogs.com/shizhongtao/p/3440479.html 接着上一篇,这里继续搜索,对于搜索和创建一样,首先你要确定搜索位置,然后用规定的类来读取.还 ...

  7. IE浏览器打开 「兼容性视图」

    有些IE上的网页控件需要打开兼容性视图才能使用,不知道是Javascript的原因,还是CSS的原因. 使用环境是用C语言配合boa服务器实现的CGI程序.

  8. [GeekBand] STL与泛型编程(3)

    本篇文章主要介绍泛型算法中的变易.排序.数值算法. 一. 变易算法 所谓变易算法是指那些改变容器中的对象的操作. 1.1 copy组 template <class InputIterator, ...

  9. 文档生产工具 Doxygen

    Doxygen是一种开源跨平台的,类似JavaDoc风格描述的文档系统,支持C.C++.Java.Objective-C等语言.可以从一套归档源文件开始,生成HTML,XML,pdf等不同风格的格式. ...

  10. linux FTP 批量下载文件

    wget是一个从网络上自动下载文件的自由工具,支持通过HTTP.HTTPS.FTP三个最常见的TCP/IP协议下载,并可以使用HTTP代理.wget名称的由来是“World Wide Web”与“ge ...