XQuery 實(shí)例
在本節(jié),讓我們通過(guò)研究一個(gè)例子來(lái)學(xué)習(xí)一些基礎(chǔ)的 XQuery 語(yǔ)法。
XML 實(shí)例文檔
我們將在下面的例子中使用這個(gè) XML 文檔。
"books.xml" :
<?xml version="1.0" encoding="ISO-8859-1"?> <bookstore> <book category="COOKING"> <title lang="en">Everyday Italian</title> <author>Giada De Laurentiis</author> <year>2005</year> <price>30.00</price> </book> <book category="CHILDREN"> <title lang="en">Harry Potter</title> <author>J K. Rowling</author> <year>2005</year> <price>29.99</price> </book> <book category="WEB"> <title lang="en">XQuery Kick Start</title> <author>James McGovern</author> <author>Per Bothner</author> <author>Kurt Cagle</author> <author>James Linn</author> <author>Vaidyanathan Nagarajan</author> <year>2003</year> <price>49.99</price> </book> <book category="WEB"> <title lang="en">Learning XML</title> <author>Erik T. Ray</author> <year>2003</year> <price>39.95</price> </book> </bookstore>
如何從 "books.xml" 選取節(jié)點(diǎn)?
函數(shù)
XQuery 使用函數(shù)來(lái)提取 XML 文檔中的數(shù)據(jù)。
doc() 用于打開(kāi) "books.xml" 文件:
doc("books.xml")
路徑表達(dá)式
XQuery 使用路徑表達(dá)式在 XML 文檔中通過(guò)元素進(jìn)行導(dǎo)航。
下面的路徑表達(dá)式用于在 "books.xml" 文件中選取所有的 title 元素:
doc("books.xml")/bookstore/book/title
(/bookstore 選取 bookstore 元素,/book 選取 bookstore 元素下的所有 book 元素,而 /title 選取每個(gè) book 元素下的所有 title 元素)
上面的 XQuery 可提取以下數(shù)據(jù):
<title lang="en">Everyday Italian</title> <title lang="en">Harry Potter</title> <title lang="en">XQuery Kick Start</title> <title lang="en">Learning XML</title>
謂語(yǔ)
XQuery 使用謂語(yǔ)來(lái)限定從 XML 文檔所提取的數(shù)據(jù)。
下面的謂語(yǔ)用于選取 bookstore 元素下的所有 book 元素,并且所選取的 book 元素下的 price 元素的值必須小于 30:
doc("books.xml")/bookstore/book[price<30]
上面的 XQuery 可提取到下面的數(shù)據(jù):
<book category="CHILDREN"> <title lang="en">Harry Potter</title> <author>J K. Rowling</author> <year>2005</year> <price>29.99</price> </book>