XQuery 入门案例

XQuery 入门案例

导入XQuery的包到项目中,准备一个courses.xml,内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<courses>
    <course category="JAVA">
        <title lang="en">3个月学会Java</title>
        <trainer>Jack</trainer>
        <year>2008</year>
        <fees>10000.00</fees>
    </course>
    <course category="Dot Net">
        <title lang="en">3个月学会.Net开发</title>
        <trainer>Eric</trainer>
        <year>2008</year>
        <fees>10000.00</fees>
    </course>
    <course category="C">
        <title lang="en">2个月学会C++</title>
        <trainer>Rose</trainer>
        <year>2014</year>
        <fees>3000.00</fees>
    </course>
    <course category="XML">
        <title lang="en">1个月学会XML</title>
        <trainer>Lucy</trainer>
        <year>2015</year>
        <fees>4000.00</fees>
    </course>
</courses>

编写一个courses.xqy文件,内容如下:

for $x in doc("courses.xml")/courses/course
where $x/fees>5000
return $x/title

此示例将显示费用大于 5000 的课程的标题元素。

创建一个基于Java 的XQuery 执行程序来读取courses.xqy,将其传递给XQuery 表达式处理器,并执行该表达式。之后将显示结果。

package com.yiidian;

import com.saxonica.xqj.SaxonXQDataSource;

import javax.xml.xquery.*;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;

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));  
      }  
   }      
}  

输出结果为:

热门文章

优秀文章