子查询
程序员文章站
2022-06-01 20:21:34
...
什么是子查询
例如 select ename , job , sal
from emp
where sal > (select avg(sal)
from emp
group by deptno);
意思就是在emp表中查找工资大于公司各部门平均值工资的人物信息。
子查询是在sql中多写一个select。
子查询必须在括号里面
将⼦查询放在⽐较条件的右侧增强可读性 ( ⼦查询可以出现在⽐较运算符的两侧)
单⾏操作符对应单⾏⼦查询,多⾏操作符对应多⾏⼦查询
子查询可用在
where
having
from
三个的后面
单行子查询:
= 等于
< 小于
> 大于
<=小于等于
>=大于等于
<>不等于
多行子查询
操作符 含义
IN 等于列表中的某⼀个值
ANY 与列表中的任意值⽐较
ALL 与列表中的所有值相
<ANY⼩于最⼤值的意思。
>ANY表示⼤于最⼩值。
=ANY等于IN。
>ALL表示⼤于最⼤值
<ALL表示⼩于最⼩值
空值加not
关联子查询``
select e.ename , e.sal , e.deptno
from emp e
where e.sal > (select avg(s.sal)
from emp s
where e.deptno = s.deptno);
普通⼦查询:在主查询执⾏之前,⼦查询⾸先执⾏⼀次。⼦查询的结果要在主查询中使⽤。
关联⼦查询:需要重复执⾏⼦查询。