将SQL查询结果作为查询条件进行查询

子查询也就是嵌套SELECT语句,一个 SELECT 语句的查询结果可以作为另一个语句的输入。
子查询能够出现在Where子句中,
也能够出现在from子句中,作为一个临时表使用,
也能够出现在select list中,作为一个字段值来返回。 

1、单行子查询 :单行子查询是指子查询的返回结果只有一行数据。当主查询语句的条件语句中引用子查询结果时可用单行比较符号(=, >, <, >=, <=, <>)来进行比较。 例:
select ename,deptno,sal from emp
where deptno=(select deptno from dept where loc='XI AN');

2、多行子查询:多行子查询就是子查询的返回结果是多行数据。当主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。
其中,IN的含义是匹配子查询结果中的任一个值即可("IN" 操作符,能够测试某个值是否在一个列表中),
ALL则必须要符合子查询的所有值才可以,
ANY要符合子查询结果的任何一个值即可。而且须注意ALL 和ANY 操作符都不可以单独使用,只能与单行比较符(=、>、< 、>= 、<= 、<>)结合使用。 例: 
1).多行子查询使用IN操作符:
查询选修了老师名叫Lee(假设唯一)的学生名字
sql> select stName from Student
where stId in(select distinct stId from score where teId=(select teId from teacher where teName='Lee'));
查询所有部门编号为A的资料: SELECT ename,job,sal FROM EMP
WHERE deptno in ( SELECT deptno FROM dept WHERE dname LIKE 'A%');

2).多行子查询使用ALL操作符:
查询有一门以上的成绩高于Lee的最高成绩的学生的名字: sql> select stName from Student 
where stId in(select distinct stId from score where score >all(select score from score where stId=(select stId from Student where stName= 'Lee') ));
3). 多行子查询使用ANY操作符号例子:查询有一门以上的成绩高于Lee的任何一门成绩的学生的名字: 
sql> select stName from Student
where stId in(select distinct stId from score where score >any(select score from score where stId=(select stId from Student where stName='Lee')));
  • 10
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值