关系运算的结果也是关系,那么这样的句子对不对?
SELECT *
FROM (SELECT ... )
WHERE ...
也就是说把FROM后面的SELECT子句的运算结果当作一个表来用.
可以
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里的一列的列名。
参考资料来源:百度百科-子查询
可以,在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子句)。
本回答被网友采纳