欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

子查询

程序员文章站 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);

普通⼦查询:在主查询执⾏之前,⼦查询⾸先执⾏⼀次。⼦查询的结果要在主查询中使⽤。
关联⼦查询:需要重复执⾏⼦查询。

相关标签: 子查询