SQL语句(五)子查询
一、子查询含义
出现在其他语句中的select语句
,称为子查询
或内查询
。
二、子查询分类
按子查询的位置分
位置 | 支持的查询 |
---|---|
SELECT 后面 |
支持标量子查询 |
FROM 后面 |
支持表子查询 |
WHERE 或HAVING 后面 |
支持标量子查询 、列子查询 和行子查询 |
EXISTS 后面 |
支持表子查询 |
按结果集的行列数不同分
分类类型 | 结果集行数 |
---|---|
标量子查询 | 一行一列 |
列子查询 | 一列多行 |
行子查询 | 一行多列 |
表子查询 | 多行多列 |
三、WHERE后面的子查询
1. 标量子查询
tips: 单行操作符(> < =等)只能搭配标量子查询
查询工资比Abel
高的所有员工信息
①查询Abel的工资
SELECT salary
FROM employees
WHERE last_name = 'Abel';
结果为单行单列
:
②查询员工的信息,满足salary>①
查询公司工资最少的员工的last_name
, job_id
, salary
:
①查询MIN(salary)
SELECT MIN(salary)
FROM employees;
②查询符号这项工资的员工,salary=①
SELECT last_name, job_id, salary
FROM employees
WHERE salary=(
SELECT MIN(salary)
FROM employees
);
查询job_id
与141号员工相同,salary
比143号员工多的员工的姓名
,job_id
和工资
①141号员工的job_id
SELECT job_id
FROM employees
WHERE employee_id=141;
②143号员工的salary
SELECT salary
FROM employees
WHERE employee_id=143;
③ 结果集映射到last_name
, job_id
, salary
,且满足条件 job_id=①
和salary>②
SELECT last_name, job_id, salary
FROM employees
WHERE job_id=(
SELECT job_id
FROM employees
WHERE employee_id=141
)AND salary>(
SELECT salary
FROM employees
WHERE employee_id=143
);
2. 列子查询(多行子查询)
使用多行操作符:
IN
/NOT IN
IN()
等价于=ANY()
NOT IN()
等价于<>ALL()
ANY
/SOME
ALL
返回location_id
是1400或1700
的部门中的所有员工姓名
使用联表查询
操作得到结果:
SELECT last_name
FROM departments d INNER JOIN employees e
ON d.department_id = e.department_id
WHERE d.location_id IN (1400, 1700);
使用列子查询
得到结果:
①查询location_id
是1400或1700
的所有部门的编号
SELECT department_id
FROM departments
WHERE location_id IN (1400, 1700);
②查询满足部门编号在列表内的员工的姓名
SELECT last_name
FROM employees
WHERE department_id IN(
SELECT department_id
FROM departments
WHERE location_id IN (1400, 1700)
);
查询其他工种
中的
比job_id
为IT_PROG
工种的任一员工工资低的
员工的:工号
,姓名
①获取IT_PROG
工种所有工资
SELECT DISTINCT salary
FROM employees
WHERE job_id='IT_PROG'
②查询其他部门中符合条件salary<min(①)
的员工信息
SELECT job_id, last_name
FROM employees
WHERE salary < ANY(
SELECT DISTINCT salary
FROM employees
WHERE job_id='IT_PROG'
) AND job_id!='IT_PROG';
3. 行子查询(结果为一行多列或多行多列)
查询员工编号最小
而且工资最高的员工信息
①查询最小的员工编号
SELECT MIN(employee_id)
FROM employees;
②查询员工的最高工资
SELECT MAX(salary)
FROM employees;
③查询符合employee_id=①,salary=②
的员工
SELECT *
FROM employees
WHERE employee_id=(
SELECT MIN(employee_id)
FROM employees
)AND salary=(
SELECT MAX(salary)
FROM employees
);
使用行子查询
的等价写法:
SELECT *
FROM employees
WHERE (employee_id, salary) = (
SELECT MIN(employee_id), MAX(salary)
FROM employees
);
四 、SELECT后面的子查询
查询每个部门
的员工个数
使用联表查询
操作:
SELECT department_name 部门名, COUNT(1) 员工数量
FROM employees e RIGHT JOIN departments d
ON e.department_id = d.department_id
GROUP BY department_name
使用子查询
:
SELECT department_id, department_name,(
SELECT COUNT(1)
FROM employees e
WHERE e.department_id=d.department_id
) 对应员工数
FROM departments d;
在使用子查询中,外部的表名的别名可以传递到子查询中,例如上面的departments
表的别名d
就传递到了子查询中。
该子查询可以理解为:
- 先获取
外层查询的结果集
- 然后对结果集的
每条记录进行遍历
,将对应的参数填入到子查询中
得到单条记录的结果拼接到新列中
五、FROM后面的子查询
查询每个部门的平均工资
的工资等级
①查询每个部门的平均工资
SELECT AVG(salary) ag,department_id
FROM employees e
WHERE e.department_id IS NOT NULL
GROUP BY department_id;
②查询对应的工资等级,连接
①的结果集和job_grades
表
SELECT department_id, ag, grade_level
FROM (
SELECT AVG(salary) ag,department_id
FROM employees e
WHERE e.department_id IS NOT NULL
GROUP BY department_id
) ag_dep INNER JOIN job_grades j
ON ag_dep.ag BETWEEN lowest_sal AND highest_sal;
即可以将子查询的结果集
作为一张表
用于联表查询操作
六、EXISTS后面的子查询
EXISTS语句的作用
EXISTS语句后的括号中填入一个子查询语句,返回的结果为false
(0
)或true
(1
),分别代表查询结果是否为空。
例:
SELECT EXISTS(SELECT employee_id FROM employees);
SELECT EXISTS(SELECT employee_id FROM employees WHERE salary=30000);
简单应用
查询有员工
的部门名
:
SELECT department_name
FROM departments d
WHERE EXISTS(
SELECT *
FROM employees e
WHERE e.department_id = d.department_id
);
这里等价于用IN
SELECT department_name
FROM departments d
WHERE d.department_id IN(
SELECT DISTINCT department_id
FROM employees
);
查询没有女票
的男神信息
使用EXISTS
语句
- 查询
男神信息
- 筛选条件:他
没有女票
等价于beauty
表中没有boyfriend_id
为当前男生的记录
等价于beauty
表中boyfriend_id
为当前男生的id
的记录不存在
SELECT *
FROM boys bo
WHERE NOT EXISTS(
SELECT *
FROM beauty b
WHERE bo.id=b.boyfriend_id
);
使用IN
完成相同的任务:
- 查询
男神信息
- 筛选条件:他
没有女票
等价于当前男生的id
不在beauty
表中boyfriend_id
字段的集合中
SELECT *
FROM boys b
WHERE b.id NOT IN(
SELECT boyfriend_id
FROM beauty
);
SQL语句(五)子查询的更多相关文章
- SQL语句:子查询
一,子查询定义: 子查询就是嵌套在主查询中的查询. 子查询可以嵌套在主查询中所有位置,包括SELECT.FROM.WHERE.GROUP BY.HAVING.ORDER BY. 但并不是每个位置嵌套子 ...
- sql 语句 嵌套子查询 执行顺序分析
--创建测试数据create table Student(S# varchar(10),Sname nvarchar(10),Sage datetime,Ssex nvarchar(10))inser ...
- 使用SQL语句的子查询批量复制表数据
批量复制表数据这里有两种方法,下面分别来介绍这两种方法: 一.手动创建新表,然后复制数据 如果是要复制整个表的话,可以使用SQL SERVER自动生成CREATE脚本: 然后在脚本中改改表名就可以了, ...
- TP的一条sql语句(子查询)
$model=M(''); $model->table(C('DB_PREFIX').'goods as g') ->join(C('DB_PREFIX').'orders as o on ...
- sql之独立子查询和相关子查询总结
1.独立子查询:顾名思义:就是子查询和外层查询不存在任何联系,是独立于外层查询的: 下面就看一个例子: 有一张订单表 Sales.Order 和一张 客户表 Sales.Customer 下面的sql ...
- 使用传入的总记录数实现一条sql语句完成分页查询
使用传入的总记录数实现一条sql语句完成分页查询 问题:在传统的分页查询的实现中不可避免的需要两条sql语句,一条用于查询数据一条用于查询总记录数.如下面的实际代码所示: Img1 当然如果使 ...
- mongodb 跟踪SQL语句及慢查询收集
有个需求:跟踪mongodb的SQL语句及慢查询收集 第一步:通过mongodb自带函数可以查看在一段时间内DML语句的运行次数. 在bin目录下面运行 ./mongostat -port 端口号 ...
- [转]在Excel中使用SQL语句实现精确查询
本文转自:http://blog.sina.com.cn/s/blog_5fc375650102e1g5.html 今天在微博上看到@数据分析精选 分享的一篇文章,是关于<在Excel中使用SQ ...
- EXISTS语句的子查询
一.EXISTS运算符简介: 使用EXISTS语句可以测试集合是否为空,EXISTS语句通常与子查询结合在一起使用.只要子查询中至少返回一个值,则EXISTS语句的值就为True.EXISTS子查询的 ...
- 在JDBC中实现SQL语句的模糊查询
在JDBC中实现SQL语句的模糊查询 在大多数情况下我们可以在JDBC中写入sql语句通过占位符的方式来直接查询,但是如果要进行模糊查询,需要转义字符才能够正常查询. sql语句: select * ...
随机推荐
- 20201123 实验三《python程序设计》实验报告
20201123 2020-2021-2 <python程序设计>实验三报告 课程:<Python程序设计>班级:2011姓名:晏鹏捷学号:20201123实验教师:王志强实验 ...
- 怎样用好PS中的钢笔工具(附练习钢笔工具网站)
想要在PS中得心应手的的描绘出自己想要的线条(也就是路径),就需要对[钢笔工具]有一个充分的理解. [钢笔工具]绘出来的线条全部都是贝赛尔曲线,所以你在学习[钢笔工具]之前,要补习一下贝赛尔曲线的常识 ...
- 35、sudo权限设置
提示:sudo的介绍在"13.linux中用户和用户组"中有详细介绍: (1)简历里要加上如下项目经验: 服务器用户权限管理改造方案与实施项目 日期: 在了解公司业务流程后,提出权 ...
- 35、mysql数据库(ddl)
35.1.数据库之库操作: 1.创建数据库(在磁盘上创建一个对应的文件夹): create database [if not exists] db_name [character set xxx]; ...
- Linux下的SSH,你知道多少?
Openssh介绍 OpenSSH 是 SSH (Secure Shell) 协议的免费开源实现.SSH协议族可以用来进行远程控制, 或在计算机之间传送文件.而实现此功能的传统方式,如telnet(终 ...
- 『心善渊』Selenium3.0基础 — 19、使用Selenium操作文件的上传和下载
目录 1.Selenium实现文件上传 (1)页面中的文件上传说明 (2)文件上传示例 (3)总结 2.Selenium实现文件下载 (1)Firefox浏览器文件下载 1)操作步骤: 2)文件下载示 ...
- 前端集合传参,springmvc后端如何接收
废话不多说,上代码 后端接收对象: class ObjectA{ private String a; private String b; private List<ObjectB> lis ...
- java 的 IO简单理解
首先要先理解什么是 stream ? stream代表的是任何有能力产出数据的数据源,或是任何有能力接收数据的接收源. 一.不同导向的 stream 1)以字节为单位从 stream 中读取或往 st ...
- 欧拉函数&筛法 模板
https://blog.csdn.net/Lytning/article/details/24432651 记牢通式 =x((p1-1)/p1) * ((p2-1)/p2)....((pn-1 ...
- linux学习之路第八天(组管理和权限管理)
组管理和权限管理 1.Linux 组基本介绍 在linux中的每个用户必须属于一个组,不能独立于组外.在linux中每个文件有所有者,所在组,其他组的概念 1)所有者 2)所在组 3)其它组 4)改变 ...