XQuery使用入门(二)

  XQuery使用入门(二) 

作者:gobitan(雨水)  日期:2007-03-31  转载请注明出处 http://blog.csdn.net/gobitan 
在《XQuery使用入门(一)》中已经采用Berkeley DB XML搭建好了实验XQuery的环境,现在就可以正式开始学习XQuery了。本文主要介绍了使用XPath查询XML文档中的元素,使用谓词对查询结果进行过滤,以及对查询结果进行包裹和排序。
为了实验后面介绍的XQuery用法,首先得准备好一份XML文档(参见putDocument命令后,这里为了描述方便书籍内容与实际不符)。文档的内容是一份书籍的列表,XML文档的根是<booklist>。
首先创建一个名为xmlDb的容器,这里容器的概念就相当于关系数据库中的一个数据库,那么存入容器中的XML文档就相当于关系数据库中的一张表。
为了区分输入的命令和系统提示的结果,以底色为灰色的区域表示输入的命令,其它表示系统提示。
dbxml> createContainer xmlDb
Creating node storage container with nodes indexed
上面底色为灰色的命令创建了一个名字为xmlDb的容器,下面的是系统操作成功后的提示。
 
dbxml> putDocument bookList.xml '<booklist>
 <book lang="en">
    <ISBN>7121021161</ISBN>
    <Name>The Art of UNIX Programming</Name>
    <Author>Eric Steven Raymond</Author>
    <Press>Addison-Wesley Professional</Press>
    <Price>59.00</Price>
 </book>
 <book lang="en">
    <ISBN>9787121039690</ISBN>
    <Name>Inside Widows Operation System</Name>
    <Author>Russinovich,M.E.</Author>
    <Author>Solomon,D.A.</Author>
    <Press>Microsoft Press</Press>
    <Price>99.00</Price>
 </book>
 <book lang="zh">
    <ISBN>0131411551</ISBN>
    <Name>Unix Network Programming</Name>
    <Author>By W. Richard Stevens</Author>
    <Author>Bill Fenner</Author>
    <Author>Andrew M.Rudoff</Author>
    <Press>Addison-Wesley Professional</Press>
    <Price>79.00</Price>
 </book>
</booklist>'
Document added, name = bookList.xml
上面的命令是将准备好的一份XML文档通过putDocument命令存入xmlDb容器中。文档的名称为bookList.xml。这里需要提醒的是,前面一步的createContainer命令会将创建成功的容器默认为当前的容器,因此存入文档时就不需要指定存入的容器了。
 
(一)使用XPath查询XML文档中的元素
XPath是一用于定位XML文档中元素位置的路径语言,通过它可以准确地定位到XML文档中的任何一个元素或属性。
XPath使用起来很简单,一看就明白。它以反斜杠’/’来分隔XML的层次关系结构。比如下面的例子就是要查询书籍的名字,根据它在XML文档中的位置就可以一次从根元素booklist然后到book元素,最后到Name,如下所示:
dbxml> query 'doc("xmlDb/bookList.xml")/booklist/book/Name'
3 objects returned for eager expression 'doc("xmlDb/bookList.xml")/booklist/book
/Name'
 
dbxml> print
<Name>The Art of UNIX Programming</Name>
<Name>Inside Widows Operation System</Name>
<Name>Unix Network Programming</Name>
 
(二)使用XQuery谓词对查询结果进行过滤
上面查询出了XML文档中所有书籍的名称,如果只想查某类书籍,比如语言是中文的。那么我们可以采用谓词对查询结果进行过滤。
谓词的使用方法是直接在想要进行过滤的元素后加上一个以方括号包含表达式即可。表达式以@符号开头,并附以布尔表达式。比如只查中文的书籍布尔表达式为lang=”zh”,完整的查询语句如下:
dbxml> query 'doc("xmlDb/bookList.xml")/booklist/book[@lang="zh"]/Name'
1 objects returned for eager expression 'doc("xmlDb/bookList.xml")/booklist/book
[@lang="zh"]/Name'
 
dbxml> print
<Name>Unix Network Programming</Name>
从上面结果可以看出,该查询语句过滤掉了lang属性不是zh的书籍的名字。
 
(三)使用XQuery命令对查询结果进行包裹
在实际的应用中,往往需要将查询的结果进行包裹,形成新格式的XML数据。比如加上<html>标记包裹成一个HTML网页,或者加上根元素形成另外一份XML文档。
这里以将书籍名称的查询结果包裹为一个订单,即加上<order>根元素。包裹的方法是先写好包裹后的格式,然后通过{}将查询结果放入其中即可。如下所示:
dbxml> query '<order>{doc("xmlDb/bookList.xml")/booklist/book[@lang="zh"]/Name}</order>'
1 objects returned for eager expression '<order>{doc("xmlDb/bookList.xml")/bookl
ist/book[@lang="zh"]/Name}</order>'
 
dbxml> print
<order><Name>Unix Network Programming</Name></order>
   通过包裹后的查询结果就形成了一份新的XML文档。
 
(四)使用XQuery命令对查询结果进行排序
在使用SQL语句的时候,对查询结果进行排序可以说是再常见不过了。这里理所当然应该介绍如何在XQuery中实现这一功能。
对XQuery查询结果进行排序比前面的几项要复杂一些。从下面的例子可以看出,它还涉及到了for、where、order by、return几个关键词。这里对for、where和return几个关键词不做多介绍。用过SQL的对order by应该非常熟悉了,但要注意在XQuery中对排序的元素(相当于关系表中的字段)的引用于SQL有些不同。它需要在元素前加上$前缀,后面遵循XPath语言规范。如下所示:
dbxml> query 'for $book in doc("xmlDb/bookList.xml")/booklist/book
where $book/@lang="en"
order by $book/Name
return $book/Name'
 
2 objects returned for eager expression 'for $book in doc("xmlDb/bookList.xml")/
booklist/book
where $book/@lang="en"
order by $book/Name
return $book/Name'
 
dbxml> print
<Name>Inside Widows Operation System</Name>
<Name>The Art of UNIX Programming</Name>
这里主要介绍了一些XQuery较为常用的使用方法,后面会逐步介绍一些较为深入的应用,欢迎关注。
 
关于作者:胡家辉,网名:雨水 目前主要专注于XML文档管理及相关技术。
 

你可能感兴趣的:(xml,unix,query,文档,NetWork,文档管理)