1、什么是子查询?子查现场都可以出现在哪里?
select语句当中嵌套select语句,被嵌套的select语句是子查询。
子查询可以出现在哪里?
select
..(select)
form
…(select)
where
….(select)
2、where子句中使用子查询
案例:找出高于平均薪资的员工信息。
select from emp where sal > avg(sal); //错误的写法where后面不能跟分组函数
第一步:找出平均薪资
select avg(sal) from emp;
+——————-+
| avg(sal) |
+——————-+
| 2073.214286 |
+——————-+
第二步:where过滤
select
from emp where sal > 2073.214286;
+———-+———-+—————-+———+——————+————-+———+————+
| EMPNO | ENAME | JOB | MGR | HIREDATE | SAL | COMM | DEPTNO |
+———-+———-+—————-+———+——————+————-+———+————+
| 7566 | JONES | MANAGER | 7839 | 1981-04-02 | 2975.00 | NULL | 20 |
| 7698 | BLAKE | MANAGER | 7839 | 1981-05-01 | 2850.00 | NULL | 30 |
| 7782 | CLARK | MANAGER | 7839 | 1981-06-09 | 2450.00 | NULL | 10 |
| 7788 | SCOTT | ANALYST | 7566 | 1987-04-19 | 3000.00 | NULL | 20 |
| 7839 | KING | PRESIDENT | NULL | 1981-11-17 | 5000.00 | NULL | 10 |
| 7902 | FORD | ANALYST | 7566 | 1981-12-03 | 3000.00 | NULL | 20 |
+———-+———-+—————-+———+——————+————-+———+————+
第一步和第二步合并。
select from emp where sal >(select avg(sal) from emp);
3、from后面嵌套子查询
案例:找出每个部门平均薪水的薪资等级。
第一步:找出每个部门平均薪水(按照部门编号分组,求sal的平均值)
select deptno,avg(sal) as avgsal from emp group by deptno;
+————+——————-+
| deptno | avgsal |
+————+——————-+
| 20 | 2175.000000 |
| 30 | 1566.666667 |
| 10 | 2916.666667 |
+————+——————-+
第二步:将以上的查询结果当做临时表t,让t表和salgrade s表连接,条件是:t.avgsal between s.losal and s.hisal
mysql> select t.
,s.grade from (select deptno,avg(sal) as avgsal from emp group by deptno) t join salgrade s on t.avgsal
between s.losal and s.hisal;
+————+——————-+———-+
| deptno | avgsal | grade |
+————+——————-+———-+
| 20 | 2175.000000 | 4 |
| 30 | 1566.666667 | 3 |
| 10 | 2916.666667 | 4 |
+————+——————-+———-+
案例:找出每个部门平均的薪水等级。
第一步:找出每个员工的薪水等级。
select e.ename,e.sal,e.deptno,s.grade from emp e join salgrade s on e.sal between s.losal and s.hisal;
+————+————-+————+———-+
| ename | sal | deptno | grade |
+————+————-+————+———-+
| SMITH | 800.00 | 20 | 1 |
| ALLEN | 1600.00 | 30 | 3 |
| WARD | 1250.00 | 30 | 2 |
| JONES | 2975.00 | 20 | 4 |
| MARTIN | 1250.00 | 30 | 2 |
| BLAKE | 2850.00 | 30 | 4 |
| CLARK | 2450.00 | 10 | 4 |
| SCOTT | 3000.00 | 20 | 4 |
| KING | 5000.00 | 10 | 5 |
| TURNER | 1500.00 | 30 | 3 |
| ADAMS | 1100.00 | 20 | 1 |
| JAMES | 950.00 | 30 | 1 |
| FORD | 3000.00 | 20 | 4 |
| MILLER | 1300.00 | 10 | 2 |
+————+————-+————+———-+
第二步:基于以上结果,继续按照deptno分组,求grade平均值。
mysql> select e.deptno,avg(s.grade) from emp e join salgrade s on e.sal between s.losal and s.hisal group by e.deptno;
+————+———————+
| deptno | avg(s.grade) |
+————+———————+
| 20 | 2.8000 |
| 30 | 2.5000 |
| 10 | 3.6667 |
+————+———————+
4、在select后面嵌套子查询。
案例:找出每个员工所在的部门名称,要求显示员工名和部门名。
mysql> select e.ename,(select d.dname from dept d where e.deptno = d.deptno) as dname from emp e;
+————+——————+
| ename | dname |
+————+——————+
| SMITH | RESEARCH |
| ALLEN | SALES |
| WARD | SALES |
| JONES | RESEARCH |
| MARTIN | SALES |
| BLAKE | SALES |
| CLARK | ACCOUNTING |
| SCOTT | RESEARCH |
| KING | ACCOUNTING |
| TURNER | SALES |
| ADAMS | RESEARCH |
| JAMES | SALES |
| FORD | RESEARCH |
| MILLER | ACCOUNTING |
+————+——————+

union(可以将查询结果集相加)

案例:找出工作岗位是SALESMAN和MANAGER的员工?
第一种:select ename,job from emp where job =’MANAGER’ or ‘SALESMAN’;
第二种:select ename,job from emp where job in(‘MANAGER’,’SALESMAN’);
+————+—————+
| ename | job |
+————+—————+
| ALLEN | SALESMAN |
| WARD | SALESMAN |
| JONES | MANAGER |
| MARTIN | SALESMAN |
| BLAKE | MANAGER |
| CLARK | MANAGER |
| TURNER | SALESMAN |
+————+—————+
第三种:union
select ename,job from emp where job =’MANAGER’ union select ename,job from emp where job =’SALESMAN’;
+————+—————+
| ename | job |
+————+—————+
| JONES | MANAGER |
| BLAKE | MANAGER |
| CLARK | MANAGER |
| ALLEN | SALESMAN |
| WARD | SALESMAN |
| MARTIN | SALESMAN |
| TURNER | SALESMAN |
+————+—————+
两张不相干的表中数据拼接在一起显示?
select ename from emp union select dname from dept;
+——————+
| ename |
+——————+
| SMITH |
| ALLEN |
| WARD |
| JONES |
| MARTIN |
| BLAKE |
| CLARK |
| SCOTT |
| KING |
| TURNER |
| ADAMS |
| JAMES |
| FORD |
| MILLER |
| ACCOUNTING |
| RESEARCH |
| SALES |
| OPERATIONS |
+——————+
mysql> select ename,sal from emp
-> union
-> select dname from dept;
ERROR 1222 (21000): The used SELECT statements have a different number of columns
两个查询的字段列数不一致