目录
前言
子查询概述
1.概念
2.分类
一、标量子查询
二、列子查询
三、行子查询
四、表子查询
前言
上一期我们讲了内外连接查询以及自连接查询,那么本期我们就学习多表查询的子查询。本期会详细讲解什么是子查询,以及子查询的相关功能,下面看正文。
表数据准备:
# 创建dept表以及插入数据
create table dept(
id int auto_increment comment 'ID' primary key,
name varchar(50) not null comment '部门名称'
)comment '部门表';
INSERT INTO dept (id, name) VALUES (1, '研发部'), (2, '市场部'),(3, '财务部'), (4,
'销售部'), (5, '总经办'), (6, '人事部');
-- 创建emp表,并插入数据
create table emp(
id int auto_increment comment 'ID' primary key,
name varchar(50) not null comment '姓名',
age int comment '年龄',
job varchar(20) comment '职位',
salary int comment '薪资',
entrydate date comment '入职时间',
managerid int comment '直属领导ID',
dept_id int comment '部门ID'
)comment '员工表';
-- 添加外键
alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references
dept(id);
INSERT INTO emp (id, name, age, job,salary, entrydate, managerid, dept_id)
VALUES
(1, '金庸', 66, '总裁',20000, '2000-01-01', null,5),
(2, '张无忌', 20, '项目经理',12500, '2005-12-05', 1,1),
(3, '杨逍', 33, '开发', 8400,'2000-11-03', 2,1),
(4, '韦一笑', 48, '开发',11000, '2002-02-05', 2,1),
(5, '常遇春', 43, '开发',10500, '2004-09-07', 3,1),
(6, '小昭', 19, '程序员鼓励师',6600, '2004-10-12', 2,1),
(7, '灭绝', 60, '财务总监',8500, '2002-09-12', 1,3),
(8, '周芷若', 19, '会计',48000, '2006-06-02', 7,3),
(9, '丁敏君', 23, '出纳',5250, '2009-05-13', 7,3),
(10, '赵敏', 20, '市场部总监',12500, '2004-10-12', 1,2),
(11, '鹿杖客', 56, '职员',3750, '2006-10-03', 10,2),
(12, '鹤笔翁', 19, '职员',3750, '2007-05-09', 10,2),
(13, '方东白', 19, '职员',5500, '2009-02-12', 10,2),
(14, '张三丰', 88, '销售总监',14000, '2004-10-12', 1,4),
(15, '俞莲舟', 38, '销售',4600, '2004-10-12', 14,4),
(16, '宋远桥', 40, '销售',4600, '2004-10-12', 14,4),
(17, '陈友谅', 42, null,2000, '2011-10-12', 1,null);
子查询概述
1.概念
SQL
语句中嵌套
SELECT
语句,称为嵌套查询,又称子查询。
SELECT * FROM t1 WHERE column1 = ( SELECT column1 FROM t2 );
子查询外部的语句可以是
INSERT / UPDATE / DELETE / SELECT
的任何一个。
2.分类
根据子查询结果不同,分为:
- A. 标量子查询(子查询结果为单个值)
- B. 列子查询(子查询结果为一列)
- C. 行子查询(子查询结果为一行)
- D. 表子查询(子查询结果为多行多列)
根据子查询位置,分为:
- A. WHERE之后
- B. FROM之后
- C. SELECT之后
一、标量子查询
子查询返回的结果是单个值(数字、字符串、日期等),最简单的形式,这种子查询称为标量子查询。
常用的操作符:
= <> > >= < <=
案例
:
注意:查询步骤是原来的查询步骤,二子查询步骤是吧前面这些步骤合为一体,作为一个查询语句指令
A. 查询 " 销售部 " 的所有员工信息完成这个需求时,我们可以将需求分解为两步:① . 查询 " 销售部 " 部门 IDselect id from dept where name = '销售部';
② . 根据 " 销售部 " 部门 ID, 查询员工信息# 第一条语句的查询结果是4 select * from emp where dept_id=4;
标量子查询语句:
select * from emp where dept_id=(select id from dept where name='销售部');
B. 查询在 " 方东白 " 入职之后的员工信息完成这个需求时,我们可以将需求分解为两步:① . 查询 方东白 的入职日期select entrydate from emp where name='方东白';
② . 查询指定入职日期之后入职的员工信息# 第一条语句查询结果是2009-02-12 select * from emp where entrydate>'2009-02-12';
标量子查询语句:
select * from emp where entrydate>(select entrydate from emp where name='方东白');
二、列子查询
子查询返回的结果是一列(可以是多行),这种子查询称为列子查询。
常用的操作符:
IN
、
NOT IN
、
ANY
、
SOME
、 ALL
操作符 | 描述 |
IN | 在指定的集合范围之内,多选一 |
NOT IN | 不在指定的集合范围之内 |
ANY | 子查询返回列表中,有任意一个满足即可 |
SOME | 与ANY等同,使用SOME的地方都可以使用ANY |
ALL | 子查询返回列表的所有值都必须满足 |
案例
:
A. 查询 " 销售部 " 和 " 市场部 " 的所有员工信息分解为以下两步 :① . 查询 " 销售部 " 和 " 市场部 " 的部门 IDselect id from dept where name in ('销售部','市场部');
② . 根据部门 ID, 查询员工信息# 查询结果是2和4 select * from emp where dept_id in (2,4);
列子查询语句:
select * from emp where dept_id in(select id from dept where name in ('销售部','市场部'));
B. 查询比 销售部 所有人工资都高的员工信息
分解为以下两步 :① . 查询所有 销售部 人员工资select id from dept where name ='销售部';
② . 比 销售部 所有人工资都高的员工信息# 财务部id结果为4 select * from emp where salary> (select max(salary) from emp where dept_id=4);
列子查询语句:
select * from emp where salary > all ( select salary from emp where dept_id = (select id from dept where name = '销售部') );
C. 查询比研发部其中任意一人工资高的员工信息分解为以下两步 :① . 查询研发部所有人工资select id from dept where name ='研发部';
② . 比研发部其中任意一人工资高的员工信息# 财务部id结果为1 select * from emp where salary> (select min(salary) from emp where dept_id=1);
列子查询语句:
select *from emp where salary> any(select salary from emp where dept_id=(select id from dept where name='研发部'));
三、行子查询
子查询返回的结果是一行(可以是多列),这种子查询称为行子查询。
常用的操作符:
=
、
<>
、
IN
、
NOT IN
案例
:
A. 查询与 " 张无忌 " 的薪资及直属领导相同的员工信息 ;这个需求同样可以拆解为两步进行 :① . 查询 " 张无忌 " 的薪资及直属领导select salary,managerid from emp where name='张无忌';
② . 查询与 " 张无忌 " 的薪资及直属领导相同的员工信息 ;select * from emp where (salary,managerid)=(select salary,managerid from emp where name='张无忌');
四、表子查询
子查询返回的结果是多行多列,这种子查询称为表子查询。
常用的操作符:
IN
案例
:
A. 查询与 " 鹿杖客 " , " 宋远桥 " 的职位和薪资相同的员工信息分解为两步执行 :① . 查询 " 鹿杖客 " , " 宋远桥 " 的职位和薪资select job,salary from emp where name in ('鹿杖客','宋远桥');
② . 查询与 " 鹿杖客 " , " 宋远桥 " 的职位和薪资相同的员工信息select* from emp where (job,salary) in (select job,salary from emp where name in ('鹿杖客','宋远桥'));
B. 查询入职日期是 "2006-01-01" 之后的员工信息 , 及其部门信息分解为两步执行 :① . 入职日期是 "2006-01-01" 之后的员工信息select * from emp where entrydate>'2006-01-01';
② . 查询这部分员工 , 对应的部门信息;select e.*,dept.* from (select * from emp where entrydate>'2006-01-01') e left join dept on e.dept_id=dept.id;
以上就是本期的全部内容了,我们下次见!
分享一张壁纸: