SQL嵌套SELECT语句的用法-will.miao
Access软件网QQ交流学习群(群号码198465573),欢迎您的加入!
首页 >技术文章> ADP及SQL SERVER


SQL嵌套SELECT语句的用法

发表时间:2018/6/3 10:18:38 评论(0) 浏览(23946)  评论 | 加入收藏 | 复制
   
摘 要:SQL嵌套SELECT语句是很常见的SQL语句,下面就为您详细介绍SQL嵌套SELECT语句的语法,并附相关示例,供您参考学习之用。
正 文:
嵌套Select语句也叫子查询,一个Select 语句的查询结果能够作为另一个语句的输入值。子查询不但能够出现在Where子句中,也能够出现在from子句中,作为一个临时表使用,也能够出现在select list中,作为一个字段值来返回。
1、单行子查询 :单行子查询是指子查询的返回结果只有一行数据。当主查询语句的条件语句中引用子查询结果时可用单行比较符号(=, >, <, >=, <=, <>)来进行比较。
例:
select ename,deptno,sal   
from emp   
where deptno=(select deptno from dept where loc='NEW YORK');  
2、多行子查询:多行子查询即是子查询的返回结果是多行数据。当主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。其中,IN的含义是匹配子查询结果中的任一个值即可("IN" 操作符,能够测试某个值是否在一个列表中),ALL则必须要符合子查询的所有值才可,ANY要符合子查询结果的任何一个值即可。而且须注意ALL 和ANY 操作符不能单独使用,而只能与单行比较符(=、>、< 、>= 、<= 、<>)结合使用。
例:
1).多行子查询使用IN操作符号例子:查询选修了老师名叫Rona(假设唯一)的学生名字
sql> select stName  
 
from Student  
 
where stId in(selectdistinct stId from score where teId=(select teId from teacher where teName='Rona'));  
查询所有部门编号为A的资料:
Select ename,job,sal  
 
FROM EMP  
 
Where deptno in ( Select deptno FROM dept Where dname LIKE 'A%');  
2).多行子查询使用ALL操作符号例子:查询有一门以上的成绩高于Kaka的最高成绩的学生的名字:
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= 'Kaka') ));  
3). 多行子查询使用ANY操作符号例子:查询有一门以上的成绩高于Kaka的任何一门成绩的学生的名字:
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='Kaka')));  
3、多列子查询:当是单行多列的子查询时,主查询语句的条件语句中引用子查询结果时可用单行比较符号(=, >, <, >=, <=, <>)来进行比较;当是多行多列子查询时,主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。
例:
Select deptno,ename,job,sal   
FROM EMP   
Where (deptno,sal) IN (Select deptno,MAX(sal) FROM EMP GROUP BY deptno);  
4、内联视图子查询
例:
(1)Select ename,job,sal,rownum   
FROM (Select ename,job,sal FROM EMP orDER BY sal);   
(2)Select ename,job,sal,rownum   
FROM ( Select ename,job,sal FROM EMP orDER BY sal)   
Where rownum<=5;  
5、在HAVING子句中使用子查询
例:
Select deptno,job,AVG(sal) FROM EMP GROUP BY deptno,job HAVING AVG(sal)>(Select sal FROM EMP Where ename='MARTIN');


Access软件网交流QQ群(群号:198465573)
 
 相关文章
SQL SERVER2005使用公用表表达式(CTE)简化嵌套SQ...  【赵文斌  2012/6/21】
怎样使用SQL Server数据库的嵌套子查询  【宏鹏  2016/10/19】
追加查询 select into from和insert into...  【yyalm  2017/9/4】
union all连接三个select语句出错  【伊西军  2018/2/8】
【IIF嵌套示例】根据不同的币种计算汇率结果,汇率计算问题,美元不...  【麥田  2018/5/2】
常见问答
技术分类
相关资源
文章搜索
关于作者

will.miao

文章分类

文章存档

友情链接