这些主要是老师上课讲的一些知识点,自己做了一些整理放在这里~~~
子查询可以是标量的、多值的或是表值的。
在期待单个值的地方可以使用标量子查询。例如,以下查询返回具有最大员工编号的员工信息:
SELECT *
FROM EMP AS E1
WHERE E1.EMPNO=( SELECT MAX(E2.EMPNO)
FROM EMP AS E2
)
只要标量子查询返回的值是单个值或不返回值,它就是有效的。然而,如果标量子查询返回多个值,则将产生运行时错误。
 
子查询可以是标量的、多值的或是表值的。
在期待多个值的地方可以使用多值子查询。例如,以下查询返回员工部门编号在部门表中存在的员工信息:
SELECT *

FROM EMP
WHERE DEPTNO IN(SELECT DEPTNO
FROM DEPT
)

子查询可以是标量的、多值的或是表值的。

在期待出现表的地方,还可以使用表值子查询或表表达式。例如,以下查询返回员工的EMPNO、ENAME和SAL,并以员工编号、员工姓名和员工薪水命名,最后以员工姓名进行排序:

SELECT *
FROM ( SELECT EMPNO AS '员工编号',
ENAME AS '员工姓名',
SAL AS '员工薪水'
FROM EMP
) AS E
ORDER BY 员工姓名
查询可以按两种方式进行分类。
按期望值的数量可以分为标量子查询和多值子查询。
按子查询对外部查询的依赖性可以分为独立子查询和相关子查询。
标量子查询和多值子查询既可以是独立子查询,也可以是相关子查询
 
独立子查询
 
独立子查询是可以独立于外部查询而运行的子查询。相对于相关子查询,独立子查询非常便于调试。
我们在前面看到的子查询都是独立子查询。例如:

SELECT *
FROM EMP AS E1
WHERE E1.EMPNO = (SELECT MAX(E2.EMPNO)
FROM EMP AS E2
)

相关子查询

逻辑上,独立子查询只为整个外部查询计算一次。

相关子查询是引用了在外部查询中出现的列的子查询。从逻辑上讲,子查询会为外部查询的每一行进行一次计算。例如,查询每个组中员工薪水最高的员工信息:

SELECT E1.EMPNO,
E1.ENAME,
E1.SAL,
E1.DEPTNO
FROM EMP AS E1
WHERE E1.SAL = ( SELECT MAX(E2.SAL)
FROM EMP AS E2
WHERE E1.DEPTNO = E2.DEPTNO
)

以上就是子查询的相关知识~~

SQL Server 子查询的更多相关文章

  1. C#构造方法(函数) C#方法重载 C#字段和属性 MUI实现上拉加载和下拉刷新 SVN常用功能介绍(二) SVN常用功能介绍(一) ASP.NET常用内置对象之——Server sql server——子查询 C#接口 字符串的本质 AJAX原生JavaScript写法

    C#构造方法(函数)   一.概括 1.通常创建一个对象的方法如图: 通过  Student tom = new Student(); 创建tom对象,这种创建实例的形式被称为构造方法. 简述:用来初 ...

  2. SQL Server子查询填充DataSet时报500内部错误的解决办法

    运行环境为Visual Studio 2010,数据库为SQL Server 2008. 执行下面SQL语句 SELECT SubsiteId, SubsiteTitle, count(Collect ...

  3. SQL Server 子查询错误:No column name was specified for column 2 of 'a' error (转载)

    问: I have a MySQL query and I ran it working fine but same query showing error in SQL Server. SQL Se ...

  4. sql server 子查询 和exists使用

    概述 子查询的概念: 当一个查询是另一个查询的条件时,称之为子查询.子查询可以嵌套在主查询中所有位置,包括SELECT.FROM.WHERE.GROUP BY.HAVING.ORDER BY. 外面的 ...

  5. SQL Server 子查询遇到的坑

    这两天改 Bug 时使用 Sql Server 的子查询遇到了一些问题,特此记录一下,之前用 MySQL 比较多,按照 MySQL 的语法其实是没有问题的. 以下面这张表为例: 执行以下 SQL: s ...

  6. SQL server 子查询、设置主键外键、变量及变量查询

    一.子查询 子查询,又叫做嵌套查询. 将一个查询语句做为一个结果集供其他SQL语句使用,就像使用普通的表一样,被当作结果集的查询语句被称为子查询. 子查询有两种类型: 一种是只返回一个单值的子查询,这 ...

  7. SQL SERVER 子查询使用Order By;按In排序

    [子查询]使用order by percent * from table order by id) a 这时发现结果没有按id排序,需要将100 percent 改成 99.999 percent 或 ...

  8. sql server——子查询

    简述: 在查询语句中包含着有另外一条查询语句,被包含的查询语句称为子查询,包含着子查询的查询就称为父查询. 总之,子查询就是在查询语句里嵌套一条或者多条查询语句. 常用子查询分类: 一.独立子查询 特 ...

  9. SQL Server子查询实例

    例子一 SELECT COUNT(*) FROM ( SELECT [PersonID] FROM [tbiz_AssScore] GROUP BY PersonID ) M 语法说明: 1).FRO ...

随机推荐

  1. webpack入门(一)——webpack 介绍

    如今的网站正在演化为web应用程序: 1. 越来越多的使用JavaScript. 2. 现代浏览器提供更广泛的接口. 3. 整页刷新的情况越来越少,甚至更多代码在同一个页面.(SPA) 因此有很多代码 ...

  2. 阿里云Centos配置iptables防火墙

    虽说阿里云推出了云盾服务,但是自己再加一层防火墙总归是更安全些,下面是我在阿里云vps上配置防火墙的过程,目前只配置INPUT.OUTPUT和FORWORD都是ACCEPT的规则 一.检查iptabl ...

  3. iPad 多任务 Spilt View & Size Class

    iPad 多任务 Spilt View & Size Class 一.多任务简介 iOS 9 以后iPad新增了多任务的支持,主要形式有三种: Slide Over (侧边快捷打开) Spil ...

  4. iOS:项目中疑难Crash问题集锦

    项目中疑难Crash问题集锦 iOS App运行中遇到Crash的情况相信大家都遇到过,开发和者测试中遇到了可能很方便的办法就是直接拿着设备连接一下,然后使用Xcode自带的工具就可以解析出Crash ...

  5. Ubuntu 14 编译安装 PHP 5.4.45 + Nginx 1.4.7 + MySQL 5.6.26 笔记

    Ubuntu 14 编译安装 PHP 5.4.45 + Nginx  1.8.0/1.4.7 + MySQL 5.6.26 笔记,主要是给自己的PC机安装,非生产环境! 一.下载必要的源码 1.1.下 ...

  6. JavaScript与DOM

    文档对象模型Document Object Model DOM(Document Object Model,文档对象模型)是一个通过和JavaScript进行内容交互的API.Javascript和D ...

  7. Flash+XML前后按钮超酷焦点图,层叠翻转图形

    Flash+XML,有“前后”按钮,可以左右点击,支持鼠标滚轮,效果流畅,推荐下载.大图尺寸:680x345 点击下载

  8. CentOS 6.5 zabbix 3.0.4 乱码问题

    中文支持 修改web端源文件来开启语言 [root@localhost /]# vim /var/www/html/zabbix/include/locales.inc.php 'zh_CN' =&g ...

  9. EF接触03

    emdx文件解读:

  10. Android本地数据存储之SQLite关系型数据库 ——SQLiteDatabase

    数据库的创建,获取,执行sql语句: 框架搭建:dao 思考: 1.数据库保存在哪里? 2.如何创建数据库?如何创建表? 3.如何更新数据库?如何更改表的列数据? 4.如何获取数据库? 5.如何修改数 ...