Сохранение значения атрибута и сопоставление его в Xquery

<a>
{
for $p in doc("x.xml")/user//district
where data($p/@population) div data($p/@area) > 20
     return <b>
                <c> {$p/@name/string()} </c>
                <d> {$p/@population div $p/@area} </d>
                <d> {$p/@city/string()}</e>
            </b>
}
</a>

Я получаю идентификатор района, но мне нужно название страны. Поэтому я хочу вернуться в район из города. Как и во фрагменте ниже, я получаю страну (id = 'f0_149'), но мне не удается сопоставить ее и вывести название страны 'Austria' вместо.

Я новичок в Xquery, поэтому я не знаю о многих вещах.

ФАЙЛ XML-ФАЙЛА:

<?xml version="1.0" encoding="UTF-8"?>
    <user xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
        <country id='f0_149' name='Austria' capital='f0_1467' population='10000000' total_area='50000' >
            <name>
                Austria
            </name>
            <district id='f0_17440' name='Burgenland' country='f0_149' capital='f0_2291' population='250000' area='5000'>
                <city id='f0_2291' country='f0_149' province='f0_17440'>
                    <name>
                        Eisenstadt
                    </name>
                    <population year='87'>
                        10102
                    </population>
                </city>

1 ответ

Решение

Вы можете использовать parent:: Ось XPath:

<c> { $p/parent::country/@name/string() } </c>
Другие вопросы по тегам