XQuery Aggiunta di elementi e attributi
Il documento di esempio XML
Utilizzeremo il documento "books.xml" negli esempi seguenti (stesso file XML dei capitoli precedenti).
Visualizza il file "books.xml" nel tuo browser .
Aggiunta di elementi e attributi al risultato
Come abbiamo visto in un capitolo precedente, possiamo includere elementi e attributi dal documento di input ("books.xml) nel risultato:
for $x in doc("books.xml")/bookstore/book/title
order by $x
return $x
L'espressione XQuery sopra includerà sia l'elemento title che l'attributo lang nel risultato, in questo modo:
<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>
L'espressione XQuery sopra restituisce gli elementi del titolo esattamente nello stesso modo in cui sono descritti nel documento di input.
Ora vogliamo aggiungere i nostri elementi e attributi al risultato!
Aggiungi elementi HTML e testo
Ora, vogliamo aggiungere alcuni elementi HTML al risultato. Metteremo il risultato in un elenco HTML, insieme a del testo:
<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>
L'espressione XQuery sopra genererà il seguente risultato:
<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>
Aggiungi attributi agli elementi HTML
Successivamente, vogliamo utilizzare l'attributo di categoria come attributo di classe nell'elenco 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>
L'espressione XQuery sopra genererà il seguente risultato:
<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>