子查询:查询语句嵌套的查询语句就是子查询,子查询语句必须要用圆括号括起来,结尾不能有分号。子查询返回的数据池可看成在内存中的一张临时表。断电关机后就消失,语句运行时才有数据。子查询得到的数据也称为数据池或者临时表。
1、where子查询
1、单值子查询基本格式:
SELECT <列名表>
FROM 表名
WHERE 字段 比较运算符 (SELECT 列名 FROM 表名WHERE 条件) ;
例:查找出与“SMITH”在同一个部门的所有职工姓名及工资
select ename,sal
from emp
where deptno=(SMITH所在的部门);
--SMITH所在的部门
select deptno from emp where ename='SMITH';
--将子查询带入外层查询
select ename,sal,deptno
from emp
where deptno=(select deptno from emp where ename='SMITH');
-----对于该子查询命令,系统执行时先执行子查询,返回一个值(即SMITH的部门号)作为主要查询(或外层查询)的条件,然后再根据该条件执行主查询选择出预期的结果,即与“SMITH”同一部门的所有职工。
2、
多值子查询基本格式:
SELECT <列名表>
FROM 表名
WHERE 字段 in/not in (SELECT 列名 FROM 表名WHERE 条件) ;
例:查找出工资在2500到3500元之间的职工所在部门的所有人员的有关信息。
select *
from emp
where deptno in (工资在2500到3500元之间的职工所在部门);
--工资在2500到3500元之间的职工所在部门号
select distinct deptno from emp where sal between 2500 and 3500;
--将多行子查询带入外层查询
select *
from emp
where deptno in (select distinct deptno from emp where sal between 2500 and 3500);
总结:1.等于号右边有一个值的时候用等于号。
2.等于号右边有多个值或者一个值的时候用in或者用=any()。
2、 From子查询
1、From子查询基本格式:
SELECT <列名表>
FROM (SELECT 列名 FROM 表名WHERE 条件)
WHERE 条件;
例:查询工作是clerk的员工姓名和工作
select ename,job
from emp
where job='CLERK';
--上题的子查询做法
select e2.ename,e2.job
from (select * from emp where job='CLERK') e2;
3、where子查询和from子查询的区别
from子查询的查询效率比where子查询要高