0

我有一个带有 XML 文档集合的 eXist-db。所有文档在顶部节点都有一个命名空间,如下所示

<TEI xmlns="http://www.tei-c.org/ns/1.0" version="5.0" xml:id="No-MM_N0001-01">

当我尝试从 REST API 查询文档以获取 //div/p 中的信息时,我得到一个空响应:

Request:
/data?_query=%2F%2Fdiv%2Fp

Response:
<exist:result xmlns:exist="http://exist.sourceforge.net/NS/exist" exist:hits="0" exist:start="1" exist:count="0" exist:compilation-time="3" exist:execution-time="3"/>

但是,当我编辑其中一个文档并删除 xmlns 时,我会从已编辑的文档中获取数据。

Request:
/data?_query=%2F%2Fdiv%2Fp

Response:
<exist:result xmlns:exist="http://exist.sourceforge.net/NS/exist" exist:hits="2" exist:start="1" exist:count="2" exist:compilation-time="1" exist:execution-time="1">
<p>
Jeg fik ikke sove –
<del rend="overstrike">j</del>
så den
<lb/>
lille striben mellem ridauerne lysne
<lb/>
mere og mere –
<del rend="overwritten">v</del>
jeg vendte mig hed
<lb/>
i sengen – Det var
<del rend="overstrike">jo</del>
så tydeli –

所以,问题是,如何在不编辑所有名称空间的情况下查询集合中的 XML 文档?

4

1 回答 1

1

你有很多选择。只是我的头顶上的一些:

  1. 您可以发送 XPath//*:div/*:p 这基本上使用通配符前缀,这意味着“任何名称空间”。

  2. 您可以使用 HTTP 将 XQuery 发布到 REST API而不是使用 HTTP GET _query,这将允许您在 XQuery 中声明名称空间绑定并使用适当的 XPath,例如

    declare namespace tei = "http://www.tei-c.org/ns/1.0";
    
    //tei:div/tei:p
    
  3. 与 (2) 类似,但您可以将 XQuery 作为文件预先存储在数据库中,然后通过 REST API 上的 HTTP GET 调用该文件,这将导致 XQuery 被执行。

其他选项也是可能的...

于 2019-06-19T19:18:58.993 回答