第六章 子查詢
1.子查詢語法:
SELECT select_list
FROM table
WHERE expr operator
(SELECT select_list
FROM table);
子查詢 (內查詢) 在主查詢之前一次執行完成。
子查詢的結果被主查詢(外查詢)使用 。
例如:誰的工資比 Abel 高?
SELECT last_name
FROM employees
WHERE salary >
(SELECT salary
FROM employees
WHERE last_name = 'Abel');
注:子查詢要包含在括號內。
將子查詢放在比較條件的右側。
單行操作符對應單行子查詢,多行操作符對應多行子查詢。
2.單行子查詢:
只返回一行。
使用單行比較操作符。
操作符 含義
= Equal to
> Greater than
>= Greater than or equal to
< Less than
<= Less than or equal to
<> Not equal to
例子:題目:返回job_id與141號員工相同,salary比143號員工多的員工姓名,job_id 和工資
SELECT last_name, 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);
2.1在子查詢中使用組函數:
題目:返回公司工資最少的員工的last_name,job_id和salary
SELECT last_name, job_id, salary
FROM employees
WHERE salary =
(SELECT MIN(salary)
FROM employees);
2.2子查詢中的 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);
2.3子查詢中的空值問題:子查詢不返回任何行
3.多行子查詢:
返回多行。
使用多行比較操作符。
操作符 含義
IN 等於列表中的任意一個
ANY 和子查詢返回的某一個值比較
ALL 和子查詢返回的所有值比較
3.1在多行子查詢中使用 ANY 操作符
題目:返回其它部門中比job_id爲‘IT_PROG’部門任一工資低的員工的員工號、姓名、job_id 以及salary
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';
3.2在多行子查詢中使用 ALL 操作符
題目:返回其它部門中比job_id爲‘IT_PROG’部門所有工資都低的員工的員工號、姓名、job_id 以及salary
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';