XQuery 添加元素和屬性
XML 實例文檔
我們將在下面的例子中使用這個 "books.xml" 文檔(和上面的章節(jié)所使用的 XML 文件相同)。
在您的瀏覽器中查看 "books.xml" 文件。
向結(jié)果添加元素和屬性
正如在前面一節(jié)看到的,我們可以在結(jié)果中引用輸入文件中的元素和屬性:
for $x in doc("books.xml")/bookstore/book/title order by $x return $x
上面的 XQuery 表達(dá)式會在結(jié)果中引用 title 元素和 lang 屬性,就像這樣:
<title lang="en">Everyday Italian</title> <title lang="en">Harry Potter</title> <title lang="en">Learning XML</title> <title lang="en">XQuery Kick Start</title>
以上 XQuery 表達(dá)式返回 title 元素的方式和它們在輸入文檔中被描述的方式的相同的。
現(xiàn)在我們要向結(jié)果添加我們自己的元素和屬性!
添加 HTML 元素和文本
現(xiàn)在,我們要向結(jié)果添加 HTML 元素。我們會把結(jié)果放在一個 HTML 列表中:
<html> <body> <h1>Bookstore</h1><ul>
{ for $x in doc("books.xml")/bookstore/book order by $x/title return<li>{data($x/title)}. Category: {data($x/@category)}</li>
}</ul>
</body> </html>
以上 XQuery 表達(dá)式會生成下面的結(jié)果:
<html> <body> <h1>Bookstore</h1> <ul> <li>Everyday Italian. Category: COOKING</li> <li>Harry Potter. Category: CHILDREN</li> <li>Learning XML. Category: WEB</li> <li>XQuery Kick Start. Category: WEB</li> </ul> </body> </html>
向 HTML 元素添加屬性
接下來,我們要把 category 屬性作為 HTML 列表中的 class 屬性來使用:
<html> <body> <h1>Bookstore</h1><ul>
{ for $x in doc("books.xml")/bookstore/book order by $x/titlereturn <li >}
</ul>
</body> </html>
上面的 XQuery 表達(dá)式可生成以下結(jié)果:
<html> <body> <h1>Bookstore</h1> <ul> <li >