1

这让我快疯了。

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

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>

非常感谢伯特

4

3 回答 3

2

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

declare default element namespace "http://rosa.openkernel/";
于 2013-05-15T11:39:07.130 回答
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/>and<value/>元素:

let $uid:=$item//*:uid/*:value
于 2013-05-15T11:40:03.837 回答
1

你可以像下面这样尝试,它是用 C# 编写的

  1. 声明 XmlNamespaceManager

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

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

doc.Load(读者);namespaceManager.AddNamespace("a", doc.DocumentElement.NamespaceURI);

  1. 查询所需数据如下
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);
}
于 2017-10-03T10:46:20.460 回答