Сохранение значения атрибута и сопоставление его в 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>