XQuery - 首个应用程序



示例

以下是一个包含多个书籍记录的书店示例 XML 文档。

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>

以下是一个示例 Xquery 文档,其中包含要对上述 XML 文档执行的查询表达式。目的是获取价格大于 30 的那些 XML 节点的 title 元素。

books.xqy

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

结果

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

验证结果

要验证结果,请使用上述 XQuery 表达式替换 环境设置一章中提供的 books.xqy(内容),然后运行 XQueryTester Java 程序。

XQuery 表达式

让我们理解上述 XQuery 表达式的每个部分。

函数使用

doc("books.xml")

doc() 是 XQuery 函数之一,用于定位 XML 源。我们在这里传入 "books.xml"。考虑到相对路径,books.xml 应位于 books.xqy 所在的相同路径中。

XPath 表达式使用

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

XQuery 大量使用 XPath 表达式,以便定位要对其进行搜索的 XML 的所需部分。我们在这里选择了 books 节点下可用的所有 book 节点。

遍历对象

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

XQuery 将 XML 数据视为对象。在上述示例中,$x 表示选定的节点,而 for 循环则遍历节点集合。

应用条件

where $x/price>30

由于 $x 表示选定的节点,所以 "/" 用于获取所需元素的值;"where" 子句用于对搜索结果进行条件设置。

返回结果

return $x/title

由于 $x 表示选定的节点,所以 "/" 用于获取所需元素的值,即 price、title;"return" 子句用于从搜索结果中返回元素。

广告