XML教程
XQuery教程
XSLT教程
XPath教程

XQuery FLWOR

XQuery FLWOR

FLWOR是首字母缩写,代表" For,Let,Where,Order by,Return"。
用于-用于选择节点序列。 让-用于将序列绑定到变量。 位置-用于过滤节点。 排序依据-用于对节点进行排序。 返回-用于指定要返回的内容(对每个节点进行一次评估)。

XQuery FLWOR示例

我们来获取一个XML文档,其中包含有关课程集合的信息。我们将使用FLWOR表达式来检索费用大于2000的那些课程的标题。
courses.xml
<?xml version="1.0" encoding="UTF-8"?>
<courses>   
   <course category="JAVA">
      <title lang="en">Learn Java in 3 Months.</title>
      <trainer>Sonoo Jaiswal</trainer>
      <year>2008</year>
      <fees>10000.00</fees>
   </course>  
    <course category="Dot Net">
      <title lang="en">Learn Dot Net in 3 Months.</title>
      <trainer>Vicky Kaushal</trainer>
      <year>2008</year>
      <fees>10000.00</fees>
   </course>
    <course category="C">
      <title lang="en">Learn C in 2 Months.</title>
      <trainer>Ramesh Kumar</trainer>
      <year>2014</year>
      <fees>3000.00</fees>
   </course>
    <course category="XML">
      <title lang="en">Learn XML in 2 Months.</title>
      <trainer>Ajeet Kumar</trainer>
      <year>2015</year>
      <fees>4000.00</fees>
   </course>  
</courses>
让我们使用名为" courses.xqy"的Xquery文档,其中包含要在上述XML文档上执行的查询表达式。
courses.xqy
let $courses := (doc("courses.xml")/courses/course)
return <results>
{
   for $x in $courses
   where $x/fees>2000
   order by $x/fees
   return $x/title
}
</results>
创建一个基于Java的XQuery执行程序,以读取courses.xqy,将其传递给XQuery表达式处理器,并执行该表达式。之后,将显示结果。
XQueryTester.java
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import javax.xml.xquery.XQConnection;
import javax.xml.xquery.XQDataSource;
import javax.xml.xquery.XQException;
import javax.xml.xquery.XQPreparedExpression;
import javax.xml.xquery.XQResultSequence;
import com.saxonica.xqj.SaxonXQDataSource;
public class XQueryTester {
   public static void main(String[] args){
      try {
         execute();
      }
      
      catch (FileNotFoundException e) {
         e.printStackTrace();
      }
      
      catch (XQException e) {
         e.printStackTrace();
      }
   }
   private static void execute() throws FileNotFoundException, XQException{
      InputStream inputStream = new FileInputStream(new File("courses.xqy"));
      XQDataSource ds = new SaxonXQDataSource();
      XQConnection conn = ds.getConnection();
      XQPreparedExpression exp = conn.prepareExpression(inputStream);
      XQResultSequence result = exp.executeQuery();
       while (result.next()) {
         System.out.println(result.getItemAsString(null));
      }
   }  
}

对XML执行XQuery

将上述三个文件放在同一位置。我们将它们放在桌面上的文件夹名称XQuery3中。使用控制台编译XQueryTester.java。您必须在计算机上安装JDK 1.5或更高版本,并且已配置类路径。
编译:
javac XQueryTester.java
执行:
java XQueryTester
输出:
XQUERY Flwor 1
昵称: 邮箱:
Copyright © 2022 立地货 All Rights Reserved.
备案号:京ICP备14037608号-4