SQL中SELECT中的FROM子句可否带另外一个SELECT

关系运算的结果也是关系,那么这样的句子对不对?SELECT*FROM(SELECT...)WHERE...也就是说把FROM后面的SELECT子句的运算结果当作一个表来用... 关系运算的结果也是关系,那么这样的句子对不对?
SELECT *
FROM (SELECT ... )
WHERE ...
也就是说把FROM后面的SELECT子句的运算结果当作一个表来用.
展开
 我来答
小萝卜关
推荐于2019-10-17 · TA获得超过1210个赞
知道答主
回答量:5
采纳率:0%
帮助的人:993
展开全部

可以

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

例1:select子查询出现在Where子句中

select ename,deptno,sal from emp where deptno=(select deptno from dept where loc='NEW YORK');

例2:select子查询出现在from子句中

SELECT ename,job,sal,rownum FROM (SELECT ename,job,sal FROM EMP ORDER BY sal); 

例3:select子查询出现在select list中,作为一个字段值来返回

SELECT ename,job,sal FROM EMP WHERE deptno in ( SELECT deptno FROM dept WHERE dname LIKE 'A%');

扩展资料

在select子句里能支持直接嵌套一个select子查询,但是该select子查询返回的结果集必须是单行,返回多行时会提示ORA-01427: single-row subquery returns more than one row(ORA-01427: 单行子查询返回多个行 ):

select ( SELECT id from data_dictionary where id=1)  From v_photosum_attach ;

select ( SELECT id from data_dictionary where id=lock_purpost)  From v_photosum_attach ;

注释:lock_purpost是表v_photosum_attach里的一列的列名。

参考资料来源:百度百科-子查询

大野瘦子
高粉答主

推荐于2019-09-21 · 繁杂信息太多,你要学会辨别
知道小有建树答主
回答量:1227
采纳率:100%
帮助的人:34.8万
展开全部

可以,在select子句里能支持另一个select语句的实现形式如下(即要配合case when关键字):

select

case when lock_purpost in(SELECT id from data_dictionary) then (SELECT name from data_dictionary where id=lock_purpost)  else lock_purpost end as lock_purpost(别名),

case when lock_framework in(SELECT id from data_dictionary) then (SELECT name from data_dictionary where id=lock_framework) else lock_framework end as lock_framework

from v_photosum_attach ;

注释:

可以在表v_photosum_attach上的一行数据行上对两个不同列lock_purpost和lock_framework各自进行一次独立的查询(另一个表,即when部分)和处理(then部分),即相当于可以在表v_photosum_attach上的同一行数据行上进行了多次查询处理。

WHERE不对,在select子句里不直接支持in、is not null等在where子句里使用的关键字。

扩展资料:

关于上述where子句里使用的关键字,例如:

select lock_purpost, (lock_purpost in(SELECT id from data_dictionary ))  From v_photosum_attach ;

再例如,执行如下语句时:

select (lock_purpost is not null)  From v_photosum_attach ;

提示ORA-00907: missing right parenthesis,即在is not null前缺失右括号。

按提示修改后,执行之:

select (lock_purpost ) is not null)  From v_photosum_attach ;

提示ORA-00923: FROM keyword not found where expected,即在is not null前缺失from关键字。由此看出,is not null关键字应该属于from子句(里的where子句)。

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
laom75
高粉答主

推荐于2016-11-11 · 关注我不会让你失望
知道大有可为答主
回答量:4.6万
采纳率:84%
帮助的人:5227万
展开全部
  可以。

  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');
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友122d3c8b1
2008-03-17 · TA获得超过520个赞
知道小有建树答主
回答量:1059
采纳率:0%
帮助的人:0
展开全部
可以,那是子查询语句。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
雨韶祎26
推荐于2018-02-26 · TA获得超过806个赞
知道答主
回答量:139
采纳率:0%
帮助的人:86.7万
展开全部
select
a.id as id,
b.name as name
from
(select id...) a,
(select name...) b
where
...
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式