带有通配符的XPath-Query无效

时间:2013-05-15 11:25:34

标签: xml xpath xquery exist-db openehr

这让我发疯了。

有人可以告诉我为什么这个查询不起作用:

xquery version "3.0";
for $item in collection("openkernel/openehr_ehr/archetyped/")
let $uid:=$item//uid/value
where $uid="51160740-171e-487c-a04d-eae267f7079a"
return $item

我知道,一定是蠢事。 // uid / value之前的双斜杠是因为我想使用查询泛型

我试图找到的XML文档驻留在这个集合中,是这样的:

<openehr-ehr_rm-Composition.composition.v1 xmlns="http://rosa.openkernel/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://rosa.openkernel/ file:/openehr-ehr_rm-Composition.composition.v1.xsd">
<Composition archetype_id="openehr-ehr_rm-Composition.composition.v1">
    <archetype_id>
        <value>openehr-ehr_rm-Composition.composition.v1</value>
    </archetype_id>
    <category>
        <defining_code>
            <code_string>431</code_string>
            <terminology_id>
                <value>openehr</value>
            </terminology_id>
        </defining_code>
        <value>persistent</value>
    </category>
    <something>a composition</something>
    <uid>
        <value>0e15d0f2-0b59-4df7-88f8-27be87e1e2ac</value>
    </uid>
    <content archetype_id="openehr-ehr_rm-ADMIN_ENTRY.admin_entry.v1" archetype_node_id="at0002">
        <archetype_id>
            <value>openehr-ehr_rm-ADMIN_ENTRY.admin_entry.v1</value>
        </archetype_id>
        <an_item>nono</an_item>
        <an_other_item>an_other_item</an_other_item>
        <something>an admin_entry</something>
        <uid>
            <value>51160740-171e-487c-a04d-eae267f7079a</value>
        </uid>
    </content>
</Composition>
</openehr-ehr_rm-Composition.composition.v1>

非常感谢 伯特

3 个答案:

答案 0 :(得分:2)

您需要考虑名称空间,请参阅http://www.w3.org/TR/xquery/#id-default-namespace

declare default element namespace "http://rosa.openkernel/";

答案 1 :(得分:1)

这是命名空间问题。

xquery version "3.0";
declare namespace rosa = "http://rosa.openkernel/";

for $item in collection("openkernel/openehr_ehr/archetyped/")
let $uid:=$item//rosa:uid/rosa:value
where $uid="51160740-171e-487c-a04d-eae267f7079a"
return $item

或者,您可以使用

声明默认命名空间
declare default element namespace "http://rosa.openkernel/";

并使用您目前为止的代码。或者,您可以使用通配符选择所有命名空间的<uid/><value/>元素:

let $uid:=$item//*:uid/*:value

答案 2 :(得分:1)

你可以尝试像吼叫,用C#写的

  
      
  1. 声明XmlNamespaceManager
  2.   

XmlDocument doc = new XmlDocument(); var namespaceManager = new XmlNamespaceManager(doc.NameTable);

  
      
  1. 使用XML阅读器或任何其他方式加载文档
  2.   

doc.Load(读取器); namespaceManager.AddNamespace(&#34; a&#34;,doc.DocumentElement.NamespaceURI);

  
      
  1. 查询所需数据
  2.   
HierObjectId uid = null;
XmlNode uidNode = doc.SelectSingleNode("//a:archetype/a:uid/a:value", namespaceManager);
if (uidNode == null)
{
     uid = HierObjectId.NewObjectId();
}
else
{
  uid = new HierObjectId(uidNode.InnerText);
}