子查询:类型、语法、和注意事项
使用子查询能解决哪些问题?
子查询语法:
select select_list from table where expr operator (select select_list from table);
- 子查询(内查询)在主查询(外查询)之前执行。
- 主查询使用子查询结果。
- 位置:select,where,from,having
1、查询谁的工资比Abel高
select last_name, salary from employees
where salary >
(select salary
from employees
where last_name = ‘Abel‘);
使用子查询注意事项
- 子查询要包含在括号内。
- 将子查询放在比较条件的右侧增强可读性(子查询可以出现在比较运算符的两侧)
- 单行操作符对应单行子查询,多行操作符对应多行子查询
单行子查询:
– 子查询中的组函数
– HAVING 子句中的子查询
- 只返回一行
- 使用单行比较操作符
操作符 | 含义 |
= | 等于 |
> | 大于 |
>= | 大于等于 |
< | 小于 |
<= | 小于等于 |
<> | 不等于 |
select last_name, job_id, salary from employees
where job_id in (select job_id from employees
where last_name like ‘Taylor‘)
and salary in
(select salary
from employees
where last_name like ‘Taylor‘);
在子查询中使用组函数
select last_name, job_id, salary from employees where
salary = (select min(salary) from employees);
子查询中的HAVING 子句
- 首先执行子查询
- 向主查询中的 HAVING 子句返回结果
select department_id, min(salary)
from employees
group by department_id
having min(salary) >
(select min(salary)
from employees
where department_id = 50);
多行子查询使用单行比较符,以下为错误写法
select employee_id, last_name
from employees
where salary =
(select min(salary)
from employees
group by department_id);
子查询中的空值问题
select last_name, job_id from employees
where job_id =
(select job_id from employees
where last_name = ‘haas‘);
多行子查询
– 使用 ALL 或 ANY
- 返回多行。
- 使用多行比较操作符。
操作符 | 含义 |
IN | 等于列表中的任何一个值 |
ANY | 必须在=, !=, >, <, <=, >= 操作符之前使用,与列表中每个值进行比较,如果没有返回任何行,说明计算结果为FALSE |
ALL | 必须在=, !=, >, <, <=, >=操作符之前使用,与列表中每个值进行比较,如果没有任何行返回,说明计算结果为TRUE |
使用范例:
在多行子查询中使用 ANY
select employee_id, last_name, job_id, salary
from employees where salary < any
(select salary
from employees
where job_id = ‘IT_PROG‘)
and job_id < > ‘IT_PROG‘;
在多行子查询中使用 ALL 操作符
select employee_id, last_name, job_id, salary
from employees
where salary < all
(select salary
from employees
where job_id = ‘IT_PROG‘)
and job_id <> ‘IT_PROG‘;
子查询中的空值
select emp.last_name
from employees emp
where emp.employee_id not in
(select mgr.manager_id
from employees mgr);