子查询

标题:子查询(嵌套查询)

所谓子查询就是一个select语句中嵌套了另外的一个或者多个select语句.
应用场景:

  1. 一条查询语句的查询条件依赖于另外一条语句的查询结果。
  2. 一条语句的查询结果是作为另外一条查询语句的查询表(查询依据)。
  3. 在DML操作中使用子查询。

需求:查找和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);

**对多行子查询只能使用多行记录比较运算符**
  1. in ----------------------- 等于列表中的任何一个
  2. any ---------------------------和子查询返回的任意一个值比较
  3. all ------------------------------和子查询返回的所有值比较
    select id,last_name from s_emp where dept_id any ( select id from s_dept where region_id =2);
    任意一个部门区域为2的员工
    select id,last_name from s_emp where dept_id not in ( select id from s_dept where region_id =2);
    select id,last_name from s_emp where dept_id != all ( select id from s_dept where region_id =2)
    查询所有区域不在2号的部门员工id和last_name
    != any 不等于其中一个 不等于a或者b !=any (2,3) 不等于2或者不等于3,满足一个久未真
    != all 不等于全部
    < all() 小于最小的
    < any()小于最大的

子查询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;

你可能感兴趣的:(子查询)