首页 > 代码库 > Oracle基础笔记六

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






本文出自 “阿成的博客” 博客,转载请与作者联系!

Oracle基础笔记六