一个select...From...Where查询语句块可以嵌套在另一个select...From...Where查询块的Where子句
中,称为嵌套查询。外层查询称为父查询,主查询。内层查询称为子查询,从查询。
子查询可以嵌套多层,子查询查询到的结果又成为父查询的条件。子查询中不能有order by分组语句。
先处理子查询,再处理父查询。 
----------------------------

1。 简单嵌套查询 
     查询选修课程号为'101'并且成绩高于学生号为'9501101'的所有学生的成绩.
select * from sclass 
where cno='101' and degree>=
(select degree from sclass where sno='9501101'and cno='101') 
select * from 成绩表
where 课程成绩<=
(select 课程成绩 from 成绩表 where 学号='20020001'and 课程代号='2002030002')
----------------------------
2。 带[not] in的嵌套查询 
    查询有选修了课程的学生。
select sno,sname from student 
where sno in(Select distinct sno from sclass)
查询没有选修了课程的学生。
select sno,sname from student 
where sno not in(Select distinct sno from sclass)

select 学生表.学号,学生表.姓名,成绩表.课程成绩,成绩表.课程代号 from 学生表,成绩表
where 学生表.学号=成绩表.学号
and 学生表.院系名称 in(Select distinct 院系名称 from 学生表) 
        ----------------------------
3。 带 some | any | all 的嵌套查询
语法:
scalar_expression{=|<>|!=|>|>=|!>|<|<=|!<}
{some|any|ALL}(子查询)
SOME是SQL中的逻辑运算符号,如果在一系列比较中,有些为TRUE,那么就为TRUE。
     ANY 是SQL中的逻辑运算符号,如果在一系列比较中,任何一个为TRUE,那么就为TRUE。
ALL 是SQL中的逻辑运算符号,如果在一系列比较中,全部都为TRUE,那么就为TRUE。

带any的嵌套查询和some的嵌套查询功能是一样的。
早期的SQL仅仅允许使用any,后来的版本为了和英语的any相区分,引入了some,
同时还保留了any关键词。
select degree from sclass where cno='101'
go
select * 
from sclass 
where cno='101' and degree >some|any(select degree from sclass where cno='101')
go
select sno from sclass where cno='101'
go
select * 
from student
where sno=some|any(select sno from sclass where cno='101')
go
select 学生表.学号,学生表.姓名,学生表.院系名称,成绩表.课程代号,成绩表.课程成绩
from 成绩表,学生表
where 成绩表.学号=学生表.学号
and 学生表.院系名称 =some|any(select 院系名称 from 学生表 where 性别='女')
select 学生表.学号,学生表.姓名,学生表.院系名称,成绩表.课程代号,成绩表.课程成绩
from 成绩表,学生表
where 成绩表.学号=学生表.学号
and 成绩表.课程成绩 <all(select 课程成绩 from 成绩表 where 课程代号='2002030001')

select emp.empno,emp.ename,emp.job,emp.sal 
from scott.emp 
where sal >some|any(select sal from scott.emp where job='MANAGER'); 
    带any的查询过程等价于两步的执行过程。 
     (1)执行“select sal from scott.emp where job='MANAGER'”,其结果如图4.22所示。 
      
     (2)查询到3个薪水值2975、2850和2450,父查询执行下列语句。 
        select emp.empno,emp.ename,emp.job,emp.sal from scott.emp 
where sal >2975 or sal>2850 or sal>2450;
        SELECT emp.empno,emp.ename,emp.job,emp.sal 
FROM scott.emp 
where sal >all(select sal from scott.emp where job='MANAGER'); 
        带all的嵌套查询与【some】的步骤相同。 
     (1)子查询,结果如图4.22所示。 
     (2)父查询执行下列语句。 
     SELECT emp.empno,emp.ename,emp.job,emp.sal 
FROM scott.emp 
WHERE sal >2975 and sal>2850 and sal>2450; 
----------------------------

4。 带exists的嵌套查询
EXISTS是SQL中的逻辑运算符号,如果子查询包含一些行,那么就为TRUE。
语法为:exists 子查询
子查询是一个受限的SELECT语句,不允许有COMPUTE子句和INTO关键字。
exists为存在之意,它只查找满足条件的哪些记录,一旦找到第一个匹配的记录后,就马上停止查找

SELECT column1 FROM table1 WHERE EXISTS ( SELECT column1 FROM table2 WHERE table1.column1 
= table2.column1 );
select * from student
where exists(select * from sclass where sclass.sno=student.sno)
select * from 学生表
where exists(select * from 成绩表 where 成绩表.学号=学生表.学号)

SELECT emp.empno,emp.ename,emp.job,emp.sal 
FROM scott.emp,scott.dept 
WHERE exists (SELECT * FROM scott.emp WHERE scott.emp.deptno=scott.dept.deptno); 
----------------------------

5。交并差操作:
交操作的嵌套查询: 
     交操作就是集合中交集的概念。属于集合A且属于集合B的元素总和就是交集。    
     (select deptno from scott.emp) intersect (select deptno from scott.dept);    
并操作的嵌套查询: 
     并操作就是集合中并集的概念。属于集合A或集合B的元素总和就是并集。 
(select id,sno from student) union (select id,sno from sclass);
      (select deptno from scott.emp) union (select deptno from scott.dept);     
     
   差操作的嵌套查询: 
     差操作就是集合中差集的概念。属于集合A且不属于集合B的元素总和就是差集。 
     (select deptno from scott.dept) minus (select deptno from scott.emp); 
       《并、交和差操作的嵌套查询要求属性具有相同的定义,包括类型和取值范围。》 
----------------------------
总结:
性能:
子查询很重要的一个方面就是性能表现。便利性是有代价的,
它取决于你所使用的表和声明的大小,数量和复杂性,还有你可能会允许你的
应用软件做处理工作。每一个查询在被主查询作为资源使用之前,
都将被完整地单独处理。如果可能的话,创造性地使用JOIN声明可以以较少的
滞后时间提供出相同的信息。
技巧:
子查询除非能确保内层select只返回一个行的值,否则应在外层where子句中用
一个in限定符,即要返回多个值,要用in或者not in哦,所以当在编译过程中出
现“子查询只返回一个值”的错误时,就要考虑是不是要用in和not in

T-SQL查询语句(二):嵌套查询的更多相关文章

  1. 超实用的SQL语句之嵌套查询

    嵌套查询 什么是嵌套查询 . 嵌套查询的意思是,一个查询语句(select-from-where)查询语句块可以嵌套在另外一个查询块的where子句中,称为嵌套查询.其中外层查询也称为父查询,主查询. ...

  2. Sql Server系列:嵌套查询

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

  3. SQL基础--查询之二--连接查询

    SQL基础--查询之二--连接查询

  4. SQL系列(二)—— 查询(select)

    在开始之前先了解下SQL中的操作分类.根据与数据库不同操作的交互,对数据不同的处理类型,可以将SQL分为四种:插入.删除.修改.查询.本篇文章中主要介绍查询操作.其实查询操作也是日常应用使用最为频繁且 ...

  5. Mysql的查询语句(联合查询、连接查询、子查询等)

    Mysql的各个查询语句(联合查询.连接查询.子查询等) 一.联合查询 关键字:union 语法形式 select语句1 union[union选项] select 语句2 union[union选项 ...

  6. mysql 存储过程:提供查询语句并返回查询执行影响的行数

    mysql 存储过程:提供查询语句并返回查询执行影响的行数DELIMITER $$ DROP PROCEDURE IF EXISTS `p_get_select_row_number`$$ CREAT ...

  7. MySQL进阶 9: 联合查询 - 查询语句1 union 查询语句2 union ...

    #进阶 : 联合查询 /* union 联合 合并: 将多条查询语句的结果合并成一个结果 语法: 查询语句1 union 查询语句2 union ... 应用语境: 要查询的结果来自多个表,但查询的列 ...

  8. SQL简单嵌套查询与非嵌套查询的比较(MSSQL2005)

    某天的工作是修复某个项目的bug,接着就发现,其sql极其混乱,有非常多的left join和in操作,还有嵌套查询(只有一个表的嵌套查询).不知道看到过哪里的资料说,嵌套查询速度慢,于是我把全部嵌套 ...

  9. [原创]java WEB学习笔记90:Hibernate学习之路-- -HQL检索方式,分页查询,命名查询语句,投影查询,报表查询

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

随机推荐

  1. 随记两个SHELL文本处理

    1,对于AWK通配符的处理 例如文本: AAAAAAAA(CZ航母STYLE+CZ航母STYLE+CZ航母STYLE+CZ航母STYLE);XXXX;CCCCC(F22战机+F22战机);33333( ...

  2. HTTP 错误500.19 -Internal Server Error

    原文:HTTP 错误500.19 -Internal Server Error HTTP 错误500.19 -Internal Server Error 错误代码 0x80070021 评论1 字号: ...

  3. Java清理临时目录文件Demo(一)

    /** * 删除单个文件 * * @param sPath * 被删除文件的文件名 * @return 单个文件删除成功返回true,否则返回false */ public static boolea ...

  4. Android性能优化:谈话Bitmap内存管理和优化

    最近除了那些忙着项目开发的事情,目前正在准备我的论文.短的时间没有写博客,今晚难得想总结.只要有一点时间.因此,为了凑合用,行.唠叨罗嗦,直接进入正题. 从事Android自移动终端的发展,想必是常常 ...

  5. selenium2入门 用Yaml文件进行元素管理 (五)

    比如界面有一个按钮,id号是test.如果进行对象化的话,就是test.click就可以了.不用每次都要去创建test对象.如果id号变了,我们也只需要改一下test的名称就行了. 使用Yaml需要用 ...

  6. UpdateModel方法

    WebForm 对 MVC 说:能否借你的UpdateModel方法来用用? 背景 ASP.NET MVC的Controller有个很不错的方法:UpdataModel (相对应的还有TryUpdat ...

  7. leetcode第35题--Valid Sudoku

    题目:Determine if a Sudoku is valid, according to: Sudoku Puzzles - The Rules. The Sudoku board could ...

  8. Linq无聊练习系列7----Insert,delete,update,attach操作练习

    /*********************Insert,delete,update,attach操作练习**********************************/            ...

  9. Step one : 熟悉Unix/Linux Shell 常见命令行 (四)

    4.了解/etc目录下的各种配置文章,学会查看/var/log下的系统日志,以及/proc下的系统运行信息 了解/etc目录下的各种配置文章 /etc/hosts  主机配置文件 /etc/netwo ...

  10. iOS基础 - 史上最难游戏

    步骤一:隐藏状态栏 步骤二:屏幕适配 步骤三:设置窗口的根控制器为导航控制器,并且设置导航条和状态栏. 步骤四:搭建设置界面 步骤五:控制器连线 步骤六:搭建关卡控制器 加载pilst文件 创建关卡模 ...