2

我想编写一个返回 XML 文档中特定元素的查询,但是当我使用路径表达式返回文档中的元素(即超出文档节点)时,它总是返回一个空序列。

这是我要查询的 XML 的前几行:

<?xml version="1.0" encoding="UTF-8"?>
<?xml-model href="http://www.tei-c.org/release/xml/tei/custom/schema/relaxng/tei_all.rng" type="application/xml" schematypens="http://relaxng.org/ns/structure/1.0"?>
<?xml-model href="http://www.tei-c.org/release/xml/tei/custom/schema/relaxng/tei_all.rng" type="application/xml"
    schematypens="http://purl.oclc.org/dsdl/schematron"?>
<TEI xmlns="http://www.tei-c.org/ns/1.0">
   <teiHeader>
      <fileDesc>
         <titleStmt>
            <title>LMW Day Book, pp. 160-161</title>

我可以在文档节点上运行查询。例如,以下以字母倒序返回文档节点:

for $file in collection("/db/apps/Step3_LMWdbk_Jana's_Files")
order by $file descending
return $file

我还可以使用 doc() 函数返回单个文档节点。但是,我不能使用路径表达式来返回文档节点中的节点。例如,以下返回一个空序列:

let $title := doc("/db/apps/Step3_LMWdbk_Jana's_Files")/TEI/teiHeader/fileDesc/titleStmt/title
return $title

我已经排除的:

为了进一步测试,我又写了几个查询,包括一个访问最外层元素(即doc(...)/TEI),一个访问所有元素(即doc(...)//cell):它们都返回一个空序列。这表明路径表达式中的错误不是根本问题。

我在 oXygen XML 编辑器中运行 XQuery。我已经将一个 eXist 数据库连接到 oXygen,并且我正在使用 eXist 数据库提供的 XQuery 引擎。我检查了我已连接到 eXist,并且我的转换方案正在使用 eXist 作为它的转换器。

4

1 回答 1

3

请注意,该文档具有默认命名空间<TEI xmlns="http://www.tei-c.org/ns/1.0">,因此请在查询前加上declare default element namespace "http://www.tei-c.org/ns/1.0". 由于您没有显示整个文档,因此可能使用了其他命名空间。

于 2017-06-24T07:27:37.210 回答