五、多表查询-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;
相关推荐
techdashen10 分钟前
dial9:给 Tokio 装上“飞行记录仪“
java·数据库·redis
2501_9010064711 分钟前
Golang怎么用gRPC Gateway_Golang gRPC Gateway教程【经典】
jvm·数据库·python
2501_9012005312 分钟前
golang如何实现错误预算Error Budget计算_golang错误预算Error Budget计算实现实战
jvm·数据库·python
2401_8676239823 分钟前
如何解决OUI图形界面无法调用_xhost与DISPLAY变量设置
jvm·数据库·python
czlczl2002092528 分钟前
Mysql读写分离的过期读问题
数据库·mysql
2401_8246976639 分钟前
CSS如何实现元素反转特效_使用transform-scaleX(-1)操作
jvm·数据库·python
皮皮学姐分享-ppx1 小时前
上市公司数字技术风险暴露数据(2010-2024)|《经济研究》同款大模型测算
大数据·网络·数据库·人工智能·chatgpt·制造
CLX05051 小时前
如何在 WordPress AMP 网站中为特定模板禁用 AMP 渲染
jvm·数据库·python
神明9311 小时前
如何实现SQL动态字段选择查询_利用反射或动态拼接字符串
jvm·数据库·python
m0_733565461 小时前
golang如何实现RabbitMQ死信队列_golang RabbitMQ死信队列实现教程
jvm·数据库·python