1. XML-QL查询实现途径
通过研究分析AT&T的查询引擎,可知XML-QL查询实现结构如下图:XML-QL查询的数据源是XML数据集,其他具有一定数据结构的数据文档、数据库等数据源通过转化成XML文档,也构成XML-QL的查询数据源。要实现XML-QL查询,需要开发一个XML-QL编译器(查询引擎),并根据查询需要编写包含QL查询语句的查询文件。编译器通过对查询文件的语法和词法结构进行分析,对XML数据源文档进行解析,最终得到我们需要的数据,并以XML(或HTML)文档的格式输出。
XML文档
或文档集合
查询引擎
(Query Engine)
XML文档
XML
文档集合
XML-QL
查询文件
为了说明问题,我们利用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] http://www.w3.org/TR/NOTE-xml-ql W3C官方文档
[6] http://ftp.informatik.rwth-aachen.de/dblp/db/journals/dr/dr1.html
[7] http://www.research.att.com/sw/tools/xmlql/
[8] http://bilbo.cis.upenn.edu/~adeutsch/xmlql-demo/html/
[9] 引擎下载地址http://www.research.att.com/sw/tools/xmlql/。