在 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
谢谢
也许你只需要一个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
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)