我想编写一个返回 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 作为它的转换器。