如何检查给定节点是不是存在于 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 文档中的主要内容,如果未能解决你的问题,请参考以下文章

检查给定 UUID 的节点是不是存在

检查xml父节点中是不是存在两个xml节点

检查给定键是不是已存在于字典中并将其递增

Firebase 规则 - 如何检查用户是不是存在于子文档中

如何检查Firebase中是不是存在具有多个字段的节点(子)?

如何检查给定网址中是不是存在图像?