五、多表查询-4.5子查询-表子查询

一、概述

子查询返回的结果是多行多列,这种子查询称为表子查询。

常用的操作符: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;
相关推荐
纪莫25 分钟前
技术面:MySQL篇(InnoDB的锁机制)
java·数据库·java面试⑧股
Filotimo_41 分钟前
在java开发中,cron表达式概念
java·开发语言·数据库
DBA小马哥1 小时前
从MongoDB迁移到金仓数据库:数据模型与业务连续性难题的保姆级指南
数据库·mongodb·dba
QZ166560951592 小时前
低误差率、高性能、符合审计要求的金融数据库审计和监测最佳实践指南
数据库·金融
愚公移码2 小时前
蓝凌EKP产品:主文档权限机制浅析
java·前端·数据库·蓝凌
此生只爱蛋2 小时前
【Redis】持久化
数据库·redis
burning_maple3 小时前
redis笔记
数据库·redis·笔记
oh LAN3 小时前
提升性能:数据库与 Druid 连接池优化指南
数据库·mysql
砚边数影3 小时前
AI数学基础(一):线性代数核心,向量/矩阵运算的Java实现
java·数据库·人工智能·线性代数·矩阵·ai编程·金仓数据库
虹科网络安全3 小时前
艾体宝新闻 | Redis 月度更新速览:2025 年 12 月
数据库·redis·缓存