首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >oracle 11.2 select子句中与联接相关的子查询不起作用

oracle 11.2 select子句中与联接相关的子查询不起作用
EN

Stack Overflow用户
提问于 2018-06-07 22:06:04
回答 1查看 325关注 0票数 0

下面的关联子查询在12c中工作得很好,但是在11.2中提到的错误失败了。有人能帮忙吗?提前谢谢。

使用11.2.0.4

代码语言:javascript
复制
SQL> column member1 format A35
column member2 format A35
select a.group#, a.SEQUENCE#, a.ARCHIVED, a.STATUS,
(SELECT Member from (SELECT Member, ROWNUM AS RN FROM v$logfile b where b.group#=a.group#) WHERE RN = 1) as Member1,
(SELECT Member from (SELECT Member, ROWNUM AS RN FROM v$logfile b where b.group#=a.group#) WHERE RN = 2) as Member2,
(a.BYTES/1024/1024)
from v$log a;SQL> SQL>   2    3    4    5  
(SELECT Member from (SELECT Member, ROWNUM AS RN FROM v$logfile b where b.group#=a.group#) WHERE RN = 1) as Member1,
                                                                                 *
ERROR at line 2:
ORA-00904: "A"."GROUP#": invalid identifier

使用12c

代码语言:javascript
复制
GROUP# SEQUENCE#  ARC STATUS   MEMBER1                        MEMBER2                        (A.BYTES/1024/1024)
------ ---------- --- -------- ------------------------------ ------------------------------ -------------------
 7     4901       YES INACTIVE /u02/oradata/PROD/redo06.log   /u02/oradata/PROD/redo07.log                   810
 9     4902       YES INACTIVE /u02/oradata/PROD/redo9.log    /u03/oradata/PROD/redo9.log                    808
10     4903       NO  CURRENT  /u02/oradata/PROD/redo10.log   /u03/oradata/PROD/redo10.log                   808
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-06-08 21:30:58

如果我错了,请有人指正我,但是如果在你的分选中没有定单条款,你就不能保证得到不同的会员。

我相信这个SQL会得到预期的结果。我已经在Oracle 11上测试过了。

代码语言:javascript
复制
WITH
    aset
    AS
        (SELECT MEMBER
              , group#
              , ROW_NUMBER ()
                    OVER (
                        PARTITION BY group# ORDER BY MEMBER
                    )
                    rn
           FROM v$logfile)
SELECT a.group#
     , a.sequence#
     , a.archived
     , a.status
     , member1
     , member2
  FROM v$log a
       LEFT OUTER JOIN (SELECT MEMBER AS member1, group#
                          FROM aset
                         WHERE rn = 1) aset1
           ON a.group# = aset1.group#
       LEFT OUTER JOIN (SELECT MEMBER AS member2, group#
                          FROM aset
                         WHERE rn = 2) aset2
           ON a.group# = aset2.group#;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50750793

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档