Ссылка на псевдоним подзапроса в Oracle - PullRequest
0 голосов
/ 25 октября 2018

У меня есть следующий запрос:

select
        A.A_ID,
        B.Lib,
        A.Lib,
        C.Lib,
        (SELECT count(*) FROM X WHERE A.A_ID = X.A_ID) AS countX,
        (SELECT count(*) FROM Y WHERE A.A_ID = Y.A_ID) AS countY,
        (SELECT count(*) FROM Z WHERE A.A_ID = Z.A_ID) AS countZ
    from
        A
    left outer join
        C
            on A.C_ID=C.C_ID
    left outer join
        B
            on A.B_ID=B.B_ID
    WHERE
        countX = 2 AND countY = 3
    ORDER BY 
        countZ DESC;

Но это дает мне следующую ошибку:

Ошибка SQL [904] [42000]: ORA-00904: "COL_5_0_": identificateur non valide

Как мне решить эту проблему?

1 Ответ

0 голосов
/ 25 октября 2018

попробуйте, как показано ниже, я думаю, вы пропустили группу типов по порядку

with cte as
(

select
        A.A_ID,
        B.Lib,
        A.Lib,
        C.Lib,
        (SELECT count(*) FROM X WHERE A.A_ID = X.A_ID) AS countX,
        (SELECT count(*) FROM Y WHERE A.A_ID = Y.A_ID) AS countY,
        (SELECT count(*) FROM Z WHERE A.A_ID = Z.A_ID) AS countZ
    from
        A
    left outer join
        C
            on A.C_ID=C.C_ID
    left outer join
        B
            on A.B_ID=B.B_ID
) select * from cte where countX = 2 AND countY = 3
    Order BY 
    countZ DESC
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...