SQL相关子查询和嵌套子查询的区别

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL相关子查询和嵌套子查询的区别相关的知识,希望对你有一定的参考价值。

SQL中相关子查询和嵌套子查询在格式上有什么区别?具体格式是什么?谁告诉下谢谢!!
谢谢这位兄弟弄了这么一大篇的文章,使我学了不少。但是好象没解决我问的问题

子查询:
使用子查询的原则
1.一个子查询必须放在圆括号中。
2.将子查询放在比较条件的右边以增加可读性。
子查询不包含 ORDER BY 子句。对一个 SELECT 语句只能用一个 ORDER BY 子句,
并且如果指定了它就必须放在主 SELECT 语句的最后。
ORDER BY 子句可以使用,并且在进行 Top-N 分析时是必须的。
3.在子查询中可以使用两种比较条件:单行运算符和多行运算符。

子查询的类型
单行子查询:从内 SELECT 语句只返回一行的查询
多行子查询:从内 SELECT 语句返回多行的查询

单行子查询
单行子查询是从内查询返回一行的查询。在该子查询类型中用一个单行操作符。幻灯片中列出了单行操作符。


显示那些 job ID 与雇员 141 相同的雇员。
SELECT last_name, job_id
FROM employees
WHERE job_id =
(SELECT job_id
FROM employees
WHERE employee_id = 141);

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);
显示 job ID 与雇员 141 相同,并且薪水 高于雇员 143 的那些雇员。

注:外和内查询可以从不同的表中取得数据。

SELECT last_name, job_id, salary
FROM employees
WHERE salary =
(SELECT MIN(salary)
FROM employees);
求所有人谁的工资最小。

SELECT department_id, MIN(salary)
FROM employees
GROUP BY department_id
HAVING MIN(salary) >
(SELECT MIN(salary)
FROM employees
WHERE department_id = 50);
求每个部门的最小工资,但是要高于50号部门的工资。

SELECT employee_id, last_name
FROM employees
WHERE salary =
(SELECT MIN(salary)
FROM employees
GROUP BY department_id);
问题出现在:单行子查询返回了多个查询值;
应改为:
SELECT employee_id, last_name
FROM employees
WHERE salary in
(SELECT MIN(salary)
FROM employees
GROUP BY department_id);

SELECT last_name, job_id
FROM employees
WHERE job_id =
(SELECT job_id
FROM employees
WHERE last_name = 'Haas');
如果子查询返回的是零值,不会对主程序造成影响;
如果子查询返回的是空值,那么会影响主程序的返回值;
SELECT employee_id,
last_name
FROM employees
WHERE employee_id NOT IN
(SELECT manager_id
FROM employees)

SELECT employee_id,
last_name
FROM employees
WHERE employee_id NOT IN
(SELECT manager_id
FROM employees
WHERE manager_id IS NOT NULL)
放在select下的子查询的返回值必须是一个具体值,
from后面也可以加子查询;
having后面也可以加子查询;
order by后面也可以;

多列子查询适应于:成对比较;非成对比较。

SELECT employee_id, manager_id, department_id
FROM employees
WHERE (manager_id, department_id) IN
(SELECT manager_id, department_id
FROM employees
WHERE employee_id IN (178,174))
AND employee_id NOT IN (178,174);

输出:176 149 80

只有要查询的东西和你子查询返回的东西一一对应上了,你的查询才能成功。
如果有一个 对应不上那么你的查询不会成功。

非成对的子查询:
SELECT employee_id, manager_id, department_id
FROM employees
WHERE manager_id IN (SELECT manager_id
FROM employees
WHERE employee_id IN (174,141))
AND department_id IN (SELECT department_id
FROM employees
WHERE employee_id IN (174,141))
AND employee_id NOT IN(174,141);
输出:144 124 50
143 124 50
142 124 50
176 149 80
上面两个程序就是成对子查询和非成对子查询两者之间的区别。

如果我想去显示员工信息,要求:员工的工资高于本部门的平均工资。
SELECT a.last_name,
a.salary,
a.department_id
FROM employees a
WHERE a.salary >
(SELECT AVG(salary)
FROM employees b
WHERE b.department_id = a.department_id);

in line view(内联视图)

SELECT a.last_name, a.salary,
a.department_id, b.salavg
FROM employees a, (SELECT department_id,
AVG(salary) salavg
FROM employees
GROUP BY department_id) b
WHERE a.department_id = b.department_id
AND a.salary > b.salavg;
参考技术A 相关子查询是嵌套查询的一种,嵌套查询分为不相关子查询和相关子查询
相关子查询不能单独执行,相关查询的where条件中有查询当前记录的某些字段值
不相关子查询相对比较简单
这两者的区别就是父查询对其有没有影响,格式就是上个回答的
参考技术B 看书是最好的办法

子查询(嵌套子查询)

参考技术A

where子句:子查询返回结果为 单行单列,单行多列,多行单列 (往往使用in,any,all)操作符
having子句:子查询返回结果 单行单列 数据,同时为了使用统计函数操作
from子句:子查询返回结果为 多行多列 ,可以按照一张 数据表(临时表) 的形式操作
select子句:了解即可,可以通过别的子句形式完成。
rownum子句:只能执行<=运算,不能执行>或者between and 区间的运算,与order by连用时,要先使用order by排序(建立个临时表)。
范例(where):

1.查询基本工资比ALLEN低的全部雇员信息
a.找到ALLEN的工资,返回一个 单行单列 的数据
b. 在where子句中里面使用子查询

2.查询与雇员7566从事统一工作且领导相同的的全部雇员信息
a.找到7566的工作和领导,返回 单行多列 的数据
b.在where子句中里面使用子查询

3.查询工资与每个部门中最低工资相同的全部雇员信息
a.查出每个部门最低工资是多少,返回 多行单列 的数据。
b.用where子句(in)
c.如果在in中子查询返回值有NULL,那么不会影响,但如果是not in 中子查询有null,那么不会返回任何值,用nvl函数(nvl(mgr,100))

4.空数据判断
在sql中提供了一个exists结构用于判断子查询是否有数据返回,如果子查询中有数据返回,则exists结构返回ture,反之返回false

范例(having)

1.查询每个部门平均工资最高的的部门名称及平均工资(最高的平均工资,肯定是统计函数的嵌套)
a.先求出部门平均工资最高的那个平均工资,返回的是 单行单列 的数据

范例(from)

1.查询薪金比ALLEN或clark多的所有员工的编号,姓名,基本工资,部门名称,领导姓名,部门人数。
a.找出所需要的表
emp:员工的编号,姓名,基本工资
dept:部门名称
emp:领导姓名
emp:统计部门人数

范例(select)
1.查询每个部门的编号,名称,位置,部门人数,平均工资

范例(rownum)
1.查询工作在CHICAGO并且入职日期最早的前2,名员工姓名,入职日期。

分页查询

练习
1.查询工资高于编号7782的员工工资,并且和7396号员工工作相同的员工编号,姓名,工资。

2.查询工资最高的员工姓名,和工资。

3.查询部门工资高于10号部门最低工资的部门编号,部门名称,及部门最低工资。

4.查询员工工资为其部门最低工资的员工编号和姓名及工资。

5.显示经理是KING的员工姓名,工资。

6.显示比员工SMITH参加工作是时间晚的员工姓名,工资,参加工作的时间。

7.使用子查询方式查询那些职员在NEW YORK工作。

8.写一个查询显示和员工SMITH工作在同一个部门的员工的姓名,日期,不包括SMITH。

9.写一个查询显示其工资比全体职员平均工资高的员工编号,姓名。

10.查询显示上级领导是KING的员工,姓名
同第五题
11.显示所有工作在RESEARCH部门的员工姓名,职位。

12.查询每个部门的部门编号,平均工资,要求部门平均工资大于20号部门的平均工资。

13.查询大于自己部门平均工资的员工姓名,工资,所在部门平均工资,高于部门平均工资的额度。

14.列出至少有一个雇员的所有部门。

15.列出薪金比\'SMITH\'多的所有雇员。

16.列出入职日期早于其直接上级的所有雇员。

17.找员工姓名和直接上级姓名。

18.显示每个部门的最高工资的员工。

19.显示工资最高的员工参加工作时间晚的员工姓名,参加工作时间。

20.显示每位经理管理员工的最低工资,及最低工资者的姓名。

21.显示平均工资最高部门的平均部门名称及平均工资。

以上是关于SQL相关子查询和嵌套子查询的区别的主要内容,如果未能解决你的问题,请参考以下文章

SQL嵌套子查询和相关子查询的执行过程有啥区别

SQL嵌套子查询和相关子查询的执行过程有啥区别

子查询(嵌套子查询)

关于SQL DELETE嵌套子查询问题

SQL Server 之 子查询与嵌套查询

相关子查询 与 嵌套子查询 有何区别 ?