这让我发疯了。
有人可以告诉我为什么这个查询不起作用:
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>
非常感谢 伯特
答案 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#写的
- 声明XmlNamespaceManager
醇>
XmlDocument doc = new XmlDocument(); var namespaceManager = new XmlNamespaceManager(doc.NameTable);
- 使用XML阅读器或任何其他方式加载文档
醇>
doc.Load(读取器); namespaceManager.AddNamespace(&#34; a&#34;,doc.DocumentElement.NamespaceURI);
- 查询所需数据
醇>
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);
}