一、概述
子查询返回的结果是多行多列,这种子查询称为表子查询。
常用的操作符:in
经常出现在from之后
二、演示
【例1】查询与"鹿掌客"、"宋院桥"的职位和薪资相同的员工信息
1、查询与"鹿掌客"、"宋院桥"的职位和薪资
返回的结果是一个表
2、查询与"鹿掌客"、"宋院桥"的职位和薪资相同的员工信息
3、合并两个,变为子查询
【例2】查询入职日期是"2006-01-01"之后的员工信息,及其部门信息
1、查询与入职日期是"2006-01-01"之后的员工信息
2、查询这部分员工对应的部门信息
【代码】
sql
-- 表子查询
-- 1、查询与"鹿掌客"、"宋院桥"的职位和薪资相同的员工信息
-- a.查询与"鹿掌客"、"宋院桥"的职位和薪资
select job, salary from emp1 where name = '鹿掌客' or name = '宋院桥'; -- 返回('职员',37500),('销售',4600)
-- b.查询与"鹿掌客"、"宋院桥"的职位和薪资相同的员工信息
select * from emp1 where (job, salary) in (('职员', 37500),('销售', 4600));
-- 合并两个,变为子查询
select * from emp1 where (job, salary) in (select job, salary from emp1 where name = '鹿掌客' or name = '宋院桥');
-- 2、查询入职日期是"2006-01-01"之后的员工信息,及其部门信息
-- a.查询与入职日期是"2006-01-01"之后的员工信息
select * from emp1 where entrydate > '2006-01-01'; -- 返回一个表
-- b.查询这部分员工对应的部门信息
select e.*, d.* from (select * from emp1 where entrydate > '2006-01-01') e left join dept1 d on e.dept_id = d.id;