XQuery - FLWOR
FLWOR 是缩写词,代表“For、Let、Where、Order by、Return”。以下列表显示了它们在 FLWOR 表达式中的含义 -
F - For - 选择所有节点的集合。
L - Let - 将结果放入 XQuery 变量中。
W - 其中 - 选择条件指定的节点。
O - 排序依据 - 对根据条件指定的节点进行排序。
R - Return - 返回最终结果。
例子
以下是一个示例 XML 文档,其中包含有关图书集合的信息。我们将使用 FLWOR 表达式来检索价格大于 30 的书籍的标题。
书籍.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 文档上执行的查询表达式。
书本网
let $books := (doc("books.xml")/books/book)
return <results>
{
for $x in $books
where $x/price>30
order by $x/price
return $x/title
}
</results>
结果
<title lang="en">Learn XQuery in 24 hours</title> <title lang="en">Learn .Net in 24 hours</title>
验证结果
要验证结果,请将books.xqy的内容(在环境设置章节中给出)替换为上面的 XQuery 表达式并执行 XQueryTester java 程序。