子查询语法:
子查询 (内查询) 在主查询之前一次执行完成。
子查询的结果被主查询(外查询)使用 。
注意事项:
子查询要包含在括号内。
将子查询放在比较条件的右侧。
单行操作符对应单行子查询,多行操作符对应多行子查询。
单行子查询:
只返回一行。
使用单行比较操作符:
操作符 | 含义 |
= | Equal to |
> | Greater than |
>= | Greater than or equal to |
< | Less than |
<= | Less than or equal to |
<> | Not equal to |
例如:
--查询员工名为chen的manager的信息
SELECT
last_name,
salary,
employee_id
FROM
employees
WHERE
employee_id = (
SELECT
manager_id
FROM
employees
WHERE
LOWER (last_name) = 'chen'
);
--返回job_id与141号员工相同,salary比143号员工多的员工姓名,job_id和工资
SELECT
job_id,
salary
FROM
employees
WHERE
job_id = (
SELECT
job_id
FROM
employees
WHERE
employee_id = 141
)
AND salary > (
SELECT
salary
FROM
employees
WHERE
employee_id = 143
);
--返回公司工资最少的员工的last_name,job_id和salary
SELECT
job_id,
last_name,
salary
FROM
employees
WHERE
salary = (
SELECT
MIN (salary)
FROM
employees
);
子查询中的 HAVING 子句:
首先执行子查询。
向主查询中的HAVING 子句返回结果
例如:
--查询最低工资大于50号部门最低工资的部门id和其最低工资
SELECT
department_id,
MIN (salary)
FROM
employees
GROUP BY
department_id
HAVING
MIN (salary) > (
SELECT
MIN (salary)
FROM
employees
WHERE
department_id = 50
);
多行子查询:
返回多行。
使用多行比较操作符。
操作符 | 含义 |
IN | 等于列表中的任意一个 |
ANY | 和子查询返回的某一个 |
ALL | 值比较 和子查询返回的所有值比较 |
例如:
--返回其它部门中比job_id为‘IT_PROG’部门任一工资低的员工的员工号、姓名、job_id 以及salary
SELECT
employee_id,
last_name,
job_id,
salary
FROM
employees
WHERE
job_id <> 'IT_PROG'
AND salary < ANY (
SELECT
salary
FROM
employees
WHERE
job_id = 'IT_PROG'
);
参考来自尚硅谷视频