XQuery Tilføj Elementer og Egenskaber

XML eksempeldokument

Vi fortsætter med at bruge denne "books.xml"-fil i de næste eksempler (og den samme XML-fil som brugt i de tidligere kapitler).

Se "books.xml"-filen i din browser.

Tilføj elementer og egenskaber til resultaterne

Som vi så i det forrige afsnit, kan vi referere til elementer og egenskaber i inputfilen i resultaterne:

for $x in doc("books.xml")/bookstore/book/title
order by $x
return $x

Denne XQuery-udtryk refererer til title-elementet og lang-attributten i resultaterne, som følger:

<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>

Denne XQuery-udtryk returnerer title-elementet på samme måde som det beskrives i input-dokumentet.

Nu skal vi tilføje vores egne elementer og egenskaber!

Tilføj HTML-elementer og tekst

Nu skal vi tilføje HTML-elementer til resultaterne. Vi vil placere resultaterne i en HTML-liste:

<html>
<body>
<h1>Bogbutik</h1>
<ul>
{
for $x in doc("books.xml")/bookstore/book
order by $x/title
return <li>{data($x/title)}. Kategori: {data($x/@category)}</li>
}
</ul>
</body>
</html>

Denne XQuery-udtrykning genererer følgende resultat:

<html>
<body>
<h1>Bogbutik</h1>
<ul>
<li>Daglig italiensk. Kategori: KØKKEN
<li>Harry Potter. Kategori: BØRN</li>
<li>Learning XML. Kategori: WEB</li>
<li>XQuery Kick Start. Kategori: WEB</li>
</ul>
</body>
</html>

Tilføj egenskaber til HTML-elementer

Vi skal bruge category-attributten som class-attribut i HTML-listen:

<html>
<body>
<h1>Bogbutik</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>

Denne XQuery-udtryk kan generere følgende resultat:

<html>
<body>
<h1>Bogbutik</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>