XQuery還可以用於將XML文件轉換為HTML頁面。 看一下下面的例子,了解XQuery是如何做到的。
這個範例中將使用與前面幾節中相同的books.xml檔案。 以下範例使用books.xml 中的XQuery提取資料並建立一個HTML表,其中包含所有書籍的標題以及價格。
檔案:books.xml 的內容如下所示 -
<?xml version="1.0" encoding="UTF-8"?>
<books>
<book category="JAVA">
<title lang="en">15天搞定Java</title>
<author>Maxsu</author>
<year>2015</year>
<price>30.00</price>
</book>
<book category="DOTNET">
<title lang="en">15天搞定.Net</title>
<author>Susen</author>
<year>2018</year>
<price>40.50</price>
</book>
<book category="XML">
<title lang="en">3天搞定XQuery</title>
<author>Yizhi</author>
<author>Maxsu</author>
<year>2016</year>
<price>50.00</price>
</book>
<book category="XML">
<title lang="en">24小時搞定XPath</title>
<author>Jazz Bee</author>
<year>2019</year>
<price>16.50</price>
</book>
</books>
下面給出了要在上面的XML文件上執行的Xquery表示式。檔案:books.xqy 的內容如下所示 -
let $books := (doc("books.xml")/books/book)
for $x in $books
let $title := $x/title/text()
let $price := $x/price/text()
order by $title
return <tr><td>{data($title)}</td><td>{$price}</td></tr>
檔案:XQueryTester.java 的內容如下所示 -
//package com.yiibai.xquery;
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("books.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));
}
}
}
編譯並執行XQueryTester.java 程式碼,得到下結果 -
註:要驗證結果,請將books.xqy 的內容(在XQuery開發環境章節中給出)替換為上面的XQuery表示式,然後執行XQueryTester java程式。
XQuery表示式
這裡我們使用了以下XQuery表示式 -
data()
函式用於評估title
元素的值,以及{}
運算子告訴XQuery處理器將data()
視為函式。 如果未使用{}
運算子,則data()
將被視為普通文字。