📅  最后修改于: 2020-12-25 04:58:32             🧑  作者: Mango
FLWOR是首字母缩写词,代表“ For,Let,Where,Order by,Return”。
让我们获取一个XML文档,其中包含有关课程集合的信息。我们将使用FLWOR表达式来检索费用大于2000的那些课程的标题。
courses.xml
Learn Java in 3 Months.
Sonoo Jaiswal
2008
10000.00
Learn Dot Net in 3 Months.
Vicky Kaushal
2008
10000.00
Learn C in 2 Months.
Ramesh Kumar
2014
3000.00
Learn XML in 2 Months.
Ajeet Kumar
2015
4000.00
让我们以名为“ courses.xqy”的Xquery文档为例,该文档包含要在上述XML文档上执行的查询表达式。
courses.xqy
let $courses := (doc("courses.xml")/courses/course)
return
{
for $x in $courses
where $x/fees>2000
order by $x/fees
return $x/title
}
创建一个基于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));
}
}
}
将以上三个文件放在同一位置。我们将它们放在桌面上的文件夹名称XQuery3中。使用控制台编译XQueryTester.java。您必须在计算机上安装JDK 1.5或更高版本,并且已配置类路径。
编译:
javac XQueryTester.java
执行:
Java XQueryTester
输出: