XQuery Dodawanie elementów i atrybutów
Przykładowy dokument XML
W poniższych przykładach użyjemy dokumentu „books.xml” (ten sam plik XML, co w poprzednich rozdziałach).
Wyświetl plik „books.xml” w przeglądarce .
Dodawanie elementów i atrybutów do wyniku
Jak widzieliśmy w poprzednim rozdziale, w wyniku możemy uwzględnić elementy i atrybuty z dokumentu wejściowego ("books.xml):
for $x in doc("books.xml")/bookstore/book/title
order by $x
return $x
Powyższe wyrażenie XQuery będzie zawierało w wyniku zarówno element title, jak i atrybut lang, w następujący sposób:
<title lang="en">Everyday Italian</title>
<title lang="en">Harry Potter</title>
<title lang="en">Learning XML</title>
<title lang="en">XQuery Kick Start</title>
Powyższe wyrażenie XQuery zwraca elementy tytułu dokładnie w taki sam sposób, jak opisano w dokumencie wejściowym.
Teraz chcemy dodać do wyniku nasze własne elementy i atrybuty!
Dodaj elementy HTML i tekst
Teraz chcemy dodać do wyniku kilka elementów HTML. Wynik umieścimy na liście HTML - razem z tekstem:
<html>
<body>
<h1>Bookstore</h1>
<ul>
{
for $x in doc("books.xml")/bookstore/book
order by $x/title
return <li>{data($x/title)}. Category: {data($x/@category)}</li>
}
</ul>
</body>
</html>
Powyższe wyrażenie XQuery wygeneruje następujący wynik:
<html>
<body>
<h1>Bookstore</h1>
<ul>
<li>Everyday Italian. Category: COOKING</li>
<li>Harry Potter. Category: CHILDREN</li>
<li>Learning XML. Category: WEB</li>
<li>XQuery Kick Start. Category: WEB</li>
</ul>
</body>
</html>
Dodaj atrybuty do elementów HTML
Następnie chcemy użyć atrybutu category jako atrybutu klasy na liście HTML:
<html>
<body>
<h1>Bookstore</h1>
<ul>
{
for $x in doc("books.xml")/bookstore/book
order by $x/title
return <li class="{data($x/@category)}">{data($x/title)}</li>
}
</ul>
</body>
</html>
Powyższe wyrażenie XQuery wygeneruje następujący wynik:
<html>
<body>
<h1>Bookstore</h1>
<ul>
<li class="COOKING">Everyday Italian</li>
<li class="CHILDREN">Harry Potter</li>
<li class="WEB">Learning XML</li>
<li class="WEB">XQuery Kick Start</li>
</ul>
</body>
</html>