XQuery - Primeiro Aplicativo

Exemplo

A seguir está um documento XML de amostra contendo os registros de uma livraria de vários livros.

books.xml

<?xml version="1.0" encoding="UTF-8"?>
<books>
   
   <book category="JAVA">
      <title lang="en">Learn Java in 24 Hours</title>
      <author>Robert</author>
      <year>2005</year>
      <price>30.00</price>
   </book>
   
   <book category="DOTNET">
      <title lang="en">Learn .Net in 24 hours</title>
      <author>Peter</author>
      <year>2011</year>
      <price>70.50</price>
   </book>
   
   <book category="XML">
      <title lang="en">Learn XQuery in 24 hours</title>
      <author>Robert</author>
      <author>Peter</author> 
      <year>2013</year>
      <price>50.00</price>
   </book>
   
   <book category="XML">
      <title lang="en">Learn XPath in 24 hours</title>
      <author>Jay Ban</author>
      <year>2010</year>
      <price>16.50</price>
   </book>
   
</books>

A seguir está um documento Xquery de amostra contendo a expressão de consulta a ser executada no documento XML acima. O objetivo é obter os elementos de título desses nós XML em que o preço é maior que 30.

books.xqy

for $x in doc("books.xml")/books/book where $x/price>30
return $x/title

Resultado

<title lang="en">Learn .Net in 24 hours</title>
<title lang="en">Learn XQuery in 24 hours</title>

Verificar Resultado

Para verificar o resultado, substitua o conteúdo de books.xqy (fornecido no capítulo Configuração do ambiente ) pela expressão XQuery acima e execute o programa java XQueryTester.

Expressões XQuery

Vamos entender cada parte da expressão XQuery acima.

Uso de funções

doc("books.xml")

doc () é uma das funções XQuery usadas para localizar a origem XML. Aqui passamos "books.xml". Considerando o caminho relativo, books.xml deve estar no mesmo caminho onde books.xqy está presente.

Uso de expressões XPath

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

XQuery usa expressões XPath intensamente para localizar a parte necessária do XML na qual a pesquisa deve ser feita. Aqui, escolhemos todos os nós de livros disponíveis no nó de livros.

Iterar os objetos

for $x in doc("books.xml")/books/book

XQuery trata os dados xml como objetos. No exemplo acima, $ x representa o nó selecionado, enquanto o loop for itera sobre a coleção de nós.

Aplicar a condição

where $x/price>30

Como $ x representa o nó selecionado, "/" é usado para obter o valor do elemento necessário; A cláusula "where" é usada para colocar uma condição nos resultados da pesquisa.

Devolve o resultado

return $x/title

Como $ x representa o nó selecionado, "/" é usado para obter o valor do elemento necessário, preço, título; A cláusula "return" é usada para retornar os elementos dos resultados da pesquisa.