所谓子查询就是一个select语句中嵌套了另外的一个或者多个select语句.
应用场景:
需求:查找和smith同部门的所有员工的id和last_name
目标:员工id,last_name
from s_emp
条件 : s_emp.dept_id = smith所在的部门的id?
select id,last_name from s_emp where dept_id =?
阶段目标: smith所在的部门的id
目标:s_emp
语法:SELECT select_list
FORM table
WHERE expr operator
(select select_list from table);
SELECT last_name,title from s_emp where title=(select title from s_emp where last_name = ‘Smith’);
子查询基本原则:
1.子查询分为两种:多行子查询和单行子查询
2.子查询可以出现在操作符的左边或者右边
3.子查询可以在很多sql命令里面使用
4.嵌套查询先执行,然后将结果传给主查询
子查询可以包含order by子句
多行子查询不能使用等于号连接
可以使用类似in一样的操作符
SELECT last_name ,first_name,title
FROM s_emp
WHERE dept_id IN
(SELECT ID
FROM s_emp
WHERE name = ‘Finance’ OR region_id = 2 );
例:SELECT dept_id,AVG(salary) FROM s_emp GROUP BY dept_id HAVING AVG(salary) > (SELECT AVG(salary) FROM s_emp WHERE dept_id = 32);
多值查询:子查询结果为多个
需求:
1.查询所有区域为2号区域的所有部门员工id和lastName
select id,last_name from s_emp where dept_id in (2号区部门);
2号区域的部门
select id from s_dept where region_id =2;
组合:
select id,last_name from s_emp where dept_id in ( select id from s_dept where region_id =2);
**对多行子查询只能使用多行记录比较运算符**
子查询2:
查找内容不确定,需要构建出来一个查询的表语法:
select 。。。。
from ( select … from … )
where …
例:select id , name b.sal from s_dept dept,(select dept_id , avg (salary) sal from s_emp group by dept_id ) b where dept.id = b.dept_id;