网站大量收购独家精品文档,联系QQ:2885784924

sql子查询 嵌套功能SELECT语句.doc

  1. 1、本文档共13页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
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); 让我们再看看一些具体的实例,   一、给出人口多于Russia(俄国)的国家名称 SELECT name FROM bbc WHERE population (SELECT population FROM bbc WHERE name=Russia)   二、给出India(印度)

文档评论(0)

xina171127 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档