Oracle子查询(复习)

概念:所谓子查询,即一个select语句中嵌套了另外的一个或者多个select语句
子查询语法
子查询(内查询) 在主查询之前一次执行完成。
子查询的结果被主查询(外查询)使用。

SELECTselect_list
FROMt able
WHERE expr operator
(SELECTselect_list
FROMtable);

注意事项:
子查询要包含在括号内。
将子查询放在比较条件的右侧。
单行操作符对应单行子查询,多行操作符对应多行子查询。

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

这里写图片描述
在子查询中使用组函数
题目:返回公司工资最少的员工的last_name,job_id和salary

SELECT last_name, job_id, 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);

这里写图片描述
多行子查询

返回多行。
使用多行比较操作符。

在多行子查询中使用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' ;

这里写图片描述
在多行子查询中使用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';

这里写图片描述

猜你喜欢

转载自blog.csdn.net/wangyeshun/article/details/82730311