0

我试图仅按名称显示节点的以下元素。

在 Xpath 中,这是我的声明://akweny[parent::akwen/nazwa="Atlantycki"]

这是我的 XML 文件

<?xml version="1.0" encoding="utf-8"?>
    <akweny>
        <akwen>
            <nazwa>Atlantycki</nazwa>
            <typ>ocean</typ>
            <powierzchnia>106450</powierzchnia>
            <akweny>
                <akwen>
                    <nazwa>Północne</nazwa>
                    <typ>morze</typ>
                    <powierzchnia>750</powierzchnia>
                </akwen>
                <akwen>
                    <nazwa>Batyckie</nazwa>
                    <typ>morze</typ>
                    <powierzchnia>386</powierzchnia>
                    <akweny>
                        <akwen>
                            <nazwa>Botnicka</nazwa>
                            <typ>zatoka</typ>
                            <powierzchnia>117</powierzchnia>
                        </akwen>
                    </akweny>
                </akwen>
            </akweny>
        </akwen>
        <akwen>
            <nazwa>Spokojny</nazwa>
            <typ>ocean</typ>
            <powierzchnia>179700</powierzchnia>
        </akwen>
    </akweny>

这是我的 DTD

<?xml version="1.0" encoding="utf-8"?>
<!ELEMENT akweny (akwen+)>
<!ELEMENT akwen (nazwa, typ, powierzchnia, akweny?)>
<!ELEMENT nazwa (#PCDATA)>
<!ELEMENT typ (#PCDATA)>
<!ELEMENT powierzchnia (#PCDATA)>

这是我的 Xquery 语句

declare function app:PokazRodzica($node as node(), $model as map(*), $name as xs
:string?) {

<table border="1" width="100%">
<th>Podrzędne</th><th>Nazwa</th><th>Typ</th><th>Powierzchnia</th><th>Edycja</th>
{
    (:DOBRE ZAPYTANIE
    for $x in doc('/db/Dane/akweny.xml/')//akweny[parent::akwen/nazwa="Atlantycki"]
    parent::akwen/nazwa="Atlantycki"]/text()
    :)

    for $x in doc('/db/Dane/akweny.xml/')//akweny[parent::akwen/nazwa="Atlantycki"]
    let $nazwa := $x/nazwa
    let $typ := $x/typ
    let $powierzchnia := $x/powierzchnia
        return 
           <tr>
            <th><img src="/exist/apps/Obrazki/lupa.jpg" alt="Podrzedny" /> {count($nazwa/text())} KLIK</th>
            <th bgcolor="#F46978">{$nazwa}</th>
            <th>{$typ}</th>
            <th>{$powierzchnia}</th>
            <th>Edytuj</th>
            </tr>
}
</table>
};

要使用我的 xml 快速测试 Xpath,您可以使用此工具:http ://www.online-toolz.com/tools/xpath-editor.php

最大的问题是 Exist-DB 数据显示不正确。

我的结果是没有想法......但它应该是节点父母......

我不知道我做错了什么。请帮我。

4

1 回答 1

2

在开始使用 eXist-db 的模板系统之前,您应该在 eXide 中测试您的 XPath。

您参考带有 的文档/db/Dane/akweny.xml/。虽然这不会出错,但您应该删除最后一个“/”,因为它不是文档名称的一部分。

然后你应该看看你的 XPath //akweny[parent::akwen/nazwa="Atlantycki"],. 您是否试图找到任何akweny父母akwennazwa孩子的价值为“Atlantycki”的人?只有一个,

<akweny>
    <akwen>
        <nazwa>Północne</nazwa>
        <typ>morze</typ>
        <powierzchnia>750</powierzchnia>
    </akwen>
    <akwen>
        <nazwa>Batyckie</nazwa>
        <typ>morze</typ>
        <powierzchnia>386</powierzchnia>
        <akweny>
            <akwen>
                <nazwa>Botnicka</nazwa>
                <typ>zatoka</typ>
                <powierzchnia>117</powierzchnia>
            </akwen>
        </akweny>
    </akwen>
</akweny>

或者您是否正在尝试检索其他内容?

尝试输入

doc('/db/Dane/akweny.xml')//akweny[parent::akwen/child::nazwa eq "Atlantycki"]

在 eXide 中并通过一次添加一个步骤来调整您的 XPath 以获得您想要的结果。

也许您正在寻找这样的东西:

<table border="1" width="100%">
<th>Podrzędne</th><th>Nazwa</th><th>Typ</th><th>Powierzchnia</th><th>Edycja</th>
{
let $nodes := doc('/db/Dane/akweny.xml/')//akweny[parent::akwen/nazwa="Atlantycki"]
for $x in $nodes/*
let $nazwa := $x/nazwa/text()
let $typ := $x/typ/text()
let $powierzchnia := $x/powierzchnia/text()
    return 
       <tr>
        <th><img src="/exist/apps/Obrazki/lupa.jpg" alt="Podrzedny" /> {count($nazwa/text())} KLIK</th>
        <th bgcolor="#F46978">{$nazwa}</th>
        <th>{$typ}</th>
        <th>{$powierzchnia}</th>
        <th>Edytuj</th>
        </tr>
}</table>

完成此操作后,请记住您必须在某处调用您的 app:PokazRodzica() 函数,例如在 index.html 中。该函数本身不显示任何内容(如 wst 上面所写)。

请将标题中的拼写更正为“使用 XPath 和 XQuery 在 eXist-db 中显示时出错”。

于 2014-03-05T07:40:03.410 回答