1.      XML-QL查询实现途径
通过研究分析AT&T的查询引擎,可知XML-QL查询实现结构如下图:XML-QL查询的数据源是XML数据集,其他具有一定数据结构的数据文档、数据库等数据源通过转化成XML文档,也构成XML-QL的查询数据源。要实现XML-QL查询,需要开发一个XML-QL编译器(查询引擎),并根据查询需要编写包含QL查询语句的查询文件。编译器通过对查询文件的语法和词法结构进行分析,对XML数据源文档进行解析,最终得到我们需要的数据,并以XML(或HTML)文档的格式输出。
XML文档 XML文档 XML XML-QL
或文档集合
查询引擎
(Query Engine)
文档集合
查询文件
为了说明问题,我们利用AT&T的查询引擎来运行我们自己编写的查询文件。工作流程解释如下:
首先构建bookdata.xml文档和bookprice.xml文档作为查询数据源,第一个文档含有图书信息,第二个文档含有图书价格信息。
然后根据查询要求编写了两个XML-QL查询文件。一个是Seach.xmlql,要求查询出版社为“高等教育出版社”的图书信息。一个是Joinquery.xmlql,将bookdata.xml和bookprice.xml文档中的作者、书籍名称和价格信息实现连接。
最后通过运行查询引擎将XML源文档和XML-QL查询文件结合形成我们关心的XML数据。
bookdata.xml文档内容如下:
<?xml version="1.0" encoding="gb2312"?>
<?xml-stylesheet type="text/xsl" href="bookdata.xsl" ?>
<lib>
       <book year="2000">
              <title>数据库系统概论</title>
              <author><lastname>萨师煊 王珊</lastname></author>
              <publisher><name>高等教育出版社</name></publisher>
       </book>
       <book year="2001">
              <title>C程序设计第二版</title>
              <author><lastname>谭浩强</lastname></author>
              <publisher><name>清华大学出版社</name></publisher>
       </book>
       <book year="2002">
              <title>编译原理</title>
              <author><lastname>陈火旺</lastname></author>
              <publisher><name>国防工业出版社</name></publisher>
       </book>       <book year="2002">
              <title>高等数学</title>
              <author><lastname>陈天德</lastname></author>
              <publisher><name>山东大学出版社</name></publisher>
       </book>       <book year="2000">
              <title>管理学</title>
              <author><lastname>周三多</lastname></author>
              <publisher><name>高等教育出版社</name></publisher>
       </book>
</lib>
bookprice.xml内容如下:
<?xml version="1.0" encoding="gb2312"?>
<bookprice>
       <book>
              <title>C程序设计第二版</title>
              <price>$20.50</price>
       </book>
       <book>
              <title>编译原理</title>
              <price>$10.00</price>
       </book>
       <book>
              <title>高等数学</title>
              <price>$5.60</price>
       </book>
       <book>
              <title>管理学</title>
              <price>$10.30</price>
       </book>
</bookprice>
查询文档search.xmlql程序清单:
function query()
{
construct <title>$title</title>
where    <lib.book>
              <title>$title</title>
              <publisher><name>”高等教育出版社"</name></publisher>
              </lib.book>  IN "bookdata.xml"
}
查询文档joinquery.xmlql程序清单:
function joinquery()
{
       construct <result>
       {
              construct <book>
                                   <title>$title</title>
                                   <author>$author</author>
                                   <price>$price</price>
                              </book>
              where <lib>
                            <book>
                                   <title.PCDATA>$title</title.PCDATA>
                                   <author>$author</author>
                            </book>
                       </lib> IN "bookdata.xml"
                       <bookprice>
                          <book>
                                   <title.PCDATA>$title</title.PCDATA>
                                   <price>$price</price>
                            </book>
                       </bookprice> IN "bookprice.xml"
       }</result>
}
2.      结束语
上述分析结果表明,作为Web环境中组织数据的一种方式,HTML描述了显示全球数据的通用方法,而XML提供了直接处理全球数据的通用方法。XML使用一个简单而有灵活的标准格式,为基于Web的应用提供了一个描述数据和交换数据的有效手段。而XML-QL作为目前比较高效的查询XML文档的语言表现出很强的实用性。
参考文献:
[1]   刘光编著,网页核心XML应用技巧与实例,清华大学出版社,2000。
[2]   栗松涛编著,XML程序设计,清华大学出版社,2001。
[3] Charles F.Goldfarb      Paul Prescod ,XML Handbook, Fourth Edition ,Publishing House of Electronics Industry, 2004.
[4]   叶毅峰等编著,XML完全手册,中国电力出版社,2001。
[5]   ; W3C官方文档
[6]   
[7] http://{域名已经过期}/sw/tools/xmlql/
[8] http://bilbo.cis.upenn.edu/~adeutsch/xmlql-demo/html/
 






                                账号登录