XML实例文档
我们将使用"books.xml"在下面的例子文件(same XML file as in the previous chapters) 。
添加元素和属性的结果
正如我们在先前的章节所看到的,我们可以包括从输入文档中的元素和属性("books.xml)中的结果:
for $x in doc("books.xml")/bookstore/book/title
order by $x
return $x
上面的XQuery表达式将包括标题元件和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表达式返回title元素,因为它们在输入文档中描述的完全相同的方式。
现在,我们要添加我们自己的元素和属性的结果!
添加HTML元素和文本
现在,我们要添加一些HTML元素的结果。 我们将会把结果以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表达式将产生以下结果:
<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列表中的类属性:
<html>
<body>
<h1>Bookstore</h1>
<ul>
{
for $x in doc("books.xml")/bookstore/book
order by $x/title
return <li class="{data($x/@category)}">{data($x/title)}</li>
}
</ul>
</body>
</html>
上面的XQuery表达式将产生以下结果:
<html>
<body>
<h1>Bookstore</h1>
<ul>
<li class="COOKING">Everyday Italian</li>
<li class="CHILDREN">Harry Potter</li>
<li class="WEB">Learning XML</li>
<li class="WEB">XQuery Kick Start</li>
</ul>
</body>
</html>