XQuery 使用XPath
XQuery 使用 XPath 表达式来限制对 XML 集合的搜索结果。
XQuery 使用XPath的示例
让我们以一个包含课程集合信息的 XML 文档为例。我们将使用 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>
接下来,我们使用三种不同类型的 XQuery 语句,它们将显示费用大于 2000 的相同结果。
XQuery XPath方式一
courses.xqy:
(: read the entire xml document :)
let $courses := doc("courses.xml")
for $x in $courses/courses/course
where $x/fees > 2000
return $x/title
创建一个基于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));
}
}
}
输出结果为:
XQuery XPath方式二
courses.xqy:
(: read all courses :)
let $courses := doc("courses.xml")/courses/course
for $x in $courses
where $x/fees > 2000
return $x/title
输出结果为:
XQuery XPath方式三
courses.xqy:
(: read courses with fees > 2000 :)
let $courses := doc("courses.xml")/courses/course[fees > 20]
for $x in $courses
return $x/title
输出结果为:
热门文章
优秀文章