MySQL中的子查询

MySQL中的子查询:

(1)什么是子查询?子查询都可以出现在哪里?
select语句中可以嵌套select语句,被嵌套的select语句就是子查询。
select子查询可以出现在select中,from中,where中。


(2)where子句中使用子查询

例题:找出高于平均工资的员工。
select eno, ename from emp
where sal > (select avg(sal) from emp);


(3)from子句中使用子查询

例题:找出每个部门平均工资的工资等级。
select a.*, s.grade
from (select deptno, avg(sal) as avgsal from emp group by deptno) as a
join salgrade s
on a.avgsal between s.lowsal and s.highsal;

例题:找出每个部门工资等级的平均值。
select e.dept, avg(s.grade)
from emp e
join salgrade s
on e.sal between s.lowsal and s.highsal
group by e.dept;


(4)在select子句中嵌套子查询

例题:找出每个员工所在的部门名称。
内连接的等值连接写法:
select e.ename, d.dname
from emp e
join dept d
on e.deptno = d.deptno;

嵌套select的写法:
select e.ename as ‘员工’, (select d.dname from dept d where e.deptno = d.deptno) as ‘部门’
from emp e;

猜你喜欢

转载自blog.csdn.net/pipizhen_/article/details/107851021