子查询

什么是子查询
例如 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);

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值