Oracle - 二级子查询无法从主查询中查看字段

时间:2016-01-25 15:06:19

标签: sql oracle

在Oracle 12c中,以下查询有效,但在Oracle 11g中没有,因为二级子查询无法从主查询中看到字段。
如何重写查询以在Oracle 11中工作?

SELECT   lvl, 
         unique_code, 
         (
            SELECT   unique_code
            FROM     (
                        SELECT   p.unique_code
                        FROM     tree p
                        WHERE    p.lvl = t.lvl - 1
                             AND p.unique_code < t.unique_code
                        ORDER BY p.unique_code DESC
                     )
            WHERE    ROWNUM = 1
         ) AS parent_unique_code
FROM     tree t     

树包含如下行:
(请不要依赖于唯一代码的格式/结构,实际上要复杂得多。)

lvl         unique_code
-----------------------
1           A
2           A/X
2           A/Y
3           A/Y/T
2           A/Z
1           B
2           B/X

预期结果如下:

lvl         unique_code   parent_unique_code
--------------------------------------------
1           A                      
2           A/X           A
2           A/Y           A
3           A/Y/T         A/Y
2           A/Z           A
1           B             
2           B/X           B

谢谢

1 个答案:

答案 0 :(得分:2)

也许您只需要在嵌套查询中使用max

SELECT   lvl, 
         unique_code, 
         (
            SELECT   max(p.unique_code)
                        FROM     tree p
                        WHERE    p.lvl = t.lvl - 1
                             AND p.unique_code < t.unique_code
         ) AS parent_unique_code FROM     tree t