如何检查给定节点是不是存在于 XML 文档中
Posted
技术标签:
【中文标题】如何检查给定节点是不是存在于 XML 文档中【英文标题】:How to check if a given node exists in XML document如何检查给定节点是否存在于 XML 文档中 【发布时间】:2014-10-02 10:53:32 【问题描述】:如何检查给定节点是否存在于 XML 文档中?
XML 示例:
<order>
<desc>
<name>Test name</name>
<code>Test code</code>
</desc>
<suborders>
<item>
<id>1000</id>
</item>
<item>
<id>2000</id>
</item>
</suborders>
<options>
<item/>
</options>
</order>
如果存在任何子订单的项目,如何检查PL/SQL?
我试过这样:
DECLARE
myxml CLOB := ...
BEGIN
SELECT extractValue(XMLTYPE(myxml), '/order/suborders/item[1]')
INTO firstSuborder
FROM DUAL;
IF (firstSuborder IS NULL) THEN
dbms_output.put_line('suborder doesnt exist');
END IF;
END;
但我得到了ORA-19025: EXTRACTVALUE returns value of only one node
。
【问题讨论】:
【参考方案1】:你可以简单地使用existsnode,这里是文档http://docs.oracle.com/cd/B19306_01/appdev.102/b14259/xdb04cre.htm#i1032763
declare
OBJECT_VALUE xmltype := xmltype(q'<order>
<desc>
<name>Test name</name>
<code>Test code</code>
</desc>
<suborders>
<item>
<id>1000</id>
</item>
<item>
<id>2000</id>
</item>
</suborders>
<options>
<item/>
</options>
</order>');
node_exists pls_integer;
begin
select existsNode(OBJECT_VALUE, '/order/suborders/item[1]') into node_exists from dual;
dbms_output.put_line('exists: ' || to_char(node_exists));
end;
【讨论】:
以上是关于如何检查给定节点是不是存在于 XML 文档中的主要内容,如果未能解决你的问题,请参考以下文章
Firebase 规则 - 如何检查用户是不是存在于子文档中