多表查询请参考另一篇文章:
【MySQL篇】多表查询知识—— 多表查询(全)_南斋孤鹤的博客-CSDN博客多表查询语法及案例:内连接,外连接,自连接,联合查询等语法及案例使用:https://blog.csdn.net/m0_64231944/article/details/127802230?spm=1001.2014.3001.5502目录
子查询概念及分类:
对子查询的理解:
1,标量子查询:
2,列子查询:
3,行子查询:
4,表子查询:
子查询实际就是查询语句嵌套查询语句,然后通过子查询语句的返回值不同可以将子查询分为不同种类;以往我们在sql语句中的where条件中的条件都是固定的值,有了子查询语句我们就可以实现将查询语句放到where条件中去;
描述:子查询的返回结果为单个的值(数字、字符串、日期等):
案例一:
案例二:
描述:子查询返回的结果是一列(可以是多行);
常用操作符:IN ,NOT IN ,ALL ,SOME ,ANY ;
案例一:
# 列子查询
# 查询销售部和市场部的所有员工信息
# 查询销售部和市场部的id
select id from dept where name='销售部' or name='市场部'; #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='销售部' or name='市场部');
案例二:
案例三:
描述:子查询的返回结果是一行(可以是多列);
案例:
# 查询与张无忌的薪资及直属领导相同的员工信息
# 查询张无忌的薪资和直属领导
select salary, managerid from emp where name='张无忌';
# 查询与张无忌的薪资及直属领导相同的员工信息
select * from emp where (salary,managerid)=(select salary, managerid from emp where name='张无忌');
描述:子查询的返回值是多行多列,也就是返回一个表格;
案例一:
# 查询与鹿杖客和宋远桥的职位和薪资相同的员工信息
select * from emp where (job, salary) in ( select job, salary from emp where name in ('鹿杖客', '宋远桥'));
案例二:
# 查询入职日期是’2006-01-01‘之后的员工信息和部门信息
# 先查询出入职在’2006-01-01‘之后员工的所有信息
# 与部门表左连接
select e.*, dept.* from (select * from emp where entrydate>'2006-01-01') e left outer join dept on e.dept_id=dept.id;
上一篇:图神经网络基础