Oracle基礎筆記六

第六章 子查詢


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';






發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章