Latest web development tutorials

ejemplos de XQuery

En esta sección, vamos a aprender mediante el estudio de un ejemplo de una sintaxis básica XQuery.


documentos de instancia XML

Vamos a utilizar este documento XML en los siguientes ejemplos.

"Books.XML":

<?xml version="1.0" encoding="ISO-8859-1"?>

<bookstore>

<book category="COOKING">
<title lang="en">Everyday Italian</title>
<author>Giada De Laurentiis</author>
<year>2005</year>
<price>30.00</price>
</book>

<book category="CHILDREN">
<title lang="en">Harry Potter</title>
<author>J K. Rowling</author>
<year>2005</year>
<price>29.99</price>
</book>

<book category="WEB">
<title lang="en">XQuery Kick Start</title>
<author>James McGovern</author>
<author>Per Bothner</author>
<author>Kurt Cagle</author>
<author>James Linn</author>
<author>Vaidyanathan Nagarajan</author>
<year>2003</year>
<price>49.99</price>
</book>

<book category="WEB">
<title lang="en">Learning XML</title>
<author>Erik T. Ray</author>
<year>2003</year>
<price>39.95</price>
</book>

</bookstore>

Ver archivo "books.xml" en su navegador .


¿Cómo seleccionar un nodo de "books.xml"?

función

XQuery utiliza funciones para extraer los datos del documento XML.

doc () se utiliza para abrir el archivo "books.xml":

doc("books.xml")

expresión de ruta

XQuery utiliza expresiones de ruta para navegar en documentos XML a través de los elementos.

La siguiente expresión de ruta para "books.xml" seleccionar todos los archivos en el elemento title:

doc("books.xml") /bookstore/book/title

(/ Librería seleccione elemento de librería, / libro Selecciona todos los elementos de libro bajo el elemento de librería, y / título Selecciona todos los elementos del título en cada elemento del libro)

El XQuery anteriormente puede extraer los siguientes datos:

<title lang="en">Everyday Italian</title>
<title lang="en">Harry Potter</title>
<title lang="en">XQuery Kick Start</title>
<title lang="en">Learning XML</title>

predicado

XQuery utiliza predicados para definir un documento XML a partir de los datos extraídos.

El siguiente predicado se utiliza para seleccionar todos los elementos de libro bajo el elemento de librería, y el valor del elemento de libro seleccionado elemento de precio menores de 30 años debe ser inferior a:

doc("books.xml")/bookstore/book [price<30]

El XQuery anteriormente se puede extraer a los siguientes datos:

<book category="CHILDREN">
<title lang="en">Harry Potter</title>
<author>J K. Rowling</author>
<year>2005</year>
<price>29.99</price>
</book>