我具有以下XML结构:
<root>
<parent>
<parent_id>1</parent_id>
<parent_value>10000</parent_value>
<child>
<child_id>11</child_id>
<other_value>1000</other_value>
</child>
<child>
<child_id>12</child_id>
<other_value>1000</other_value>
</child>
</parent>
</root>
预期输出:
CHILD_ID PARENT_VALUE
---------- ------------
11 10000
12 10000
我尝试过的事情:
WITH xtbl AS (SELECT xmltype ('<root>
<parent>
<parent_id>1</parent_id>
<parent_value>10000</parent_value>
<child>
<child_id>11</child_id>
<other_value>1000</other_value>
</child>
<child>
<child_id>12</child_id>
<other_value>1000</other_value>
</child>
</parent>
</root>') AS xcol FROM dual)
SELECT myXmlTable.*
FROM xtbl
CROSS JOIN
xmltable ('/root/parent/child'
PASSING xcol
COLUMNS child_id NUMBER (5) PATH 'child_id',
parent_value NUMBER (10) PATH './parent_value') myXmlTable;
我的查询问题是parent_value
为空。请帮忙。
答案 0 :(得分:3)
您正在寻找./parent_node
,它是当前<parent_node>
节点下的<child>
。那不存在。
您只需要升级:
parent_value NUMBER (10) PATH './../parent_value'
演示与CTE并添加了../
:
WITH xtbl AS (SELECT xmltype ('<root>
<parent>
<parent_id>1</parent_id>
<parent_value>10000</parent_value>
<child>
<child_id>11</child_id>
<other_value>1000</other_value>
</child>
<child>
<child_id>12</child_id>
<other_value>1000</other_value>
</child>
</parent>
</root>') AS xcol FROM dual)
SELECT myXmlTable.*
FROM xtbl
CROSS JOIN
xmltable ('/root/parent/child'
PASSING xcol
COLUMNS child_id NUMBER (5) PATH 'child_id',
parent_value NUMBER (10) PATH './../parent_value') myXmlTable;
CHILD_ID PARENT_VALUE
---------- ------------
11 10000
12 10000
答案 1 :(得分:1)
我不知道这是最优化还是最短的版本,但是它可以工作:
WITH xtbl AS (SELECT xmltype ('<root>
<parent>
<parent_id>1</parent_id>
<parent_value>10000</parent_value>
<child>
<child_id>11</child_id>
<other_value>1000</other_value>
</child>
<child>
<child_id>12</child_id>
<other_value>1000</other_value>
</child>
</parent>
</root>') AS xcol FROM dual)
SELECT myXmlTable.*
FROM xtbl
CROSS JOIN
XMLTABLE ('for $c in /root/parent/child
return <child parent_value="{$c/../parent_value}">{$c}</child>'
PASSING xcol COLUMNS
child_id NUMBER (5) PATH 'child/child_id',
parent_value NUMBER (10) PATH '@parent_value'
) myXmlTable;
答案 2 :(得分:0)
我们在 Oracle 12.2.0.1.0 中遇到了同样的问题 - 即 PLSQL 查询没有使用 ./../ 语法从 XML 数据中返回父节点值。在我们的例子中,一个 MATERIALIZE 提示导致返回空值 - 不知道为什么,但是当删除提示时,父节点问题消失了。