一种基于XML的Web数据快速查询方法技术

技术编号:8883304 阅读:237 留言:0更新日期:2013-07-04 02:06
本发明专利技术提供一种基于XML的Web数据快速查询方法,在现在Web领域,对数据的快速查找和响应成为影响用户使用的重要指标,而大部分的Web的数据是以XML提供的文档结构来实现的,针对XML匹配等方面存在的问题提出了一种灵活的模式树匹配方法HPM(High-Performance-Match),该方法能够在XML中直接找到一个查询模式树的匹配结果,所有的中间结果集在堆栈中保存起来,通过连接运算很好的形成最后的查询匹配结果,提高了查询匹配的成功概率,达到了快速响应用户需求的目的。

【技术实现步骤摘要】

本专利技术涉及计算机应用
,具体地说是。
技术介绍
目前,Web应用中如何在XML文档中高效的查询是一个关键问题,尤其是路径表达式的计算。在XPath中使用传统的路径表达式来浏览XML文档的嵌套层次结构,而在XQuery查询语言中,传统的路径表达式不仅是结构化文档上的一个基本操作,而且成为几乎所有复杂操作的组成部分,但是这种XML查询计算的方法需要遍历整个文档,效率低下。在现阶段,这种传统的XML查询算法以及策略主要存在以下3个方面的问题: 1)这些算法大都是基于先匹配后合并步骤进行查询匹配处理,缺点是产生了大量无用的中间结果,产生了许多无用的重复匹配; 2)现在算法存在着传统索引效率不高的问题,导致了查询的效率下降比较大; 3)对查询结果的连接算法存在着输入集合中的元素必须有序,传统的索引结构是无序的,因此会产生大量不必要的重复匹配,引起性能的下降。
技术实现思路
本专利技术的目的是提供。本专利技术的目的是按以下方式实现的,通过双层的双向树索引结构HPT在XML中直接找到一个查询模式树的匹配结果,所有的中间结果集在堆栈中保存起来,最终形成最后的查询匹配结果,以此提高查询匹配的成功概率,达到了快速响应用户需求的目的,具体内容如下: 两层的HPT双向树索引结构,HPT是High-Performance-Tree的英文缩写,HPT双向树索引结构,包括组层和元素层,元素层提供详细的子节点到父节点的连接,能够方便的找到相关节点的父节点,因此双向树索引结构HPT是一种能够处理XML结构查询的快速索引,组层内的元素索引是基于组的,这样方便结构查询时根据组进行,去掉多余的查询空间,减少匹配次数能够提高效率和方便查询,传统的路径索引方法是同一个组内元素是无序的,而双向树索引结构HPT是把具有相同路径信息的节点放到一个组内,也就是说,如果两个节点是等同的,在该索引结构中就把它们放到一个组内,这样就能大大的提高XML数据的查询效率,HPT索引结构的定义及具体实现方式如下: HPT中的每个节点g称为一个组,每个组的信息包括标识符g.1d和组名称g.name,查询匹配时,根据查询模式树中节点名称和g.name进行匹配,第一,每个组包括一个元素数组g.Pid□,在组中用一个数组保存组中元素的父节点信息,第二,HPT中边是有方向的,假设有边gl—〉g2,那么组gl叫做组g2的父组,组g2叫做组gl的子组;第三,组g中数组g.pid的值表示组中第(k+1)个元素的父节点在组g的父组中的数组的索引位置;为了提高查询效率,减少匹配次数采用HPM模式树匹配方法进行查询模式树的匹配,HPM是High-Performance-Match的英文缩写,HPM模式树匹配方法如下: 设定查询HPM模式树节点q和XML数据源中节点P,如果q是叶子节点,且节点P和节点q标记相同,则称P和q相匹配;如果q是非叶子节点,同时存在节点p和以p为根结点的子树和查询模式树中节点q以及以q为根结点的子树相匹配,那么P和q相匹配,在HPM模式树匹配方法中,对查询模式树中的每一个节点,设计一个栈和一个列表,栈用来存储和查询模式树节点相匹配的数据源中的节点集合,列表存储的是查询模式树对应的HPT中组P中的元素数组,Gpacurrent表示目前正在匹配的组中的节点,该方法的基本实现流程为:给一个查询模式树和生成的数据源HPT,首先调用广度优先算法把查询模式树中的节点压栈,然后在栈上调用HPM模式树匹配方法,在数据源中找到与查询模式树中节点相匹配的节点,并且把结果存储在堆栈中,最后调用函数把中间结果连接起来得到与查询模式树相匹配的节点集合; HPM模式树匹配算法的具体实现方式如下: 首先利用广度优先对查询模式树进行遍历,然后对遍历到的节点压栈,得到查询模式树栈S,HPM式树匹配算法是用来查找查询模式树栈S在XML数据源中相匹配的节点,在HPM式树匹配算法中,对应一个查询模式树的q节点,Sq.value表示栈Sq中Gq.value的值集合,它表示栈Sq中元素的父节点在父组中的位置,再HPM模式树匹配算法判断查询模式树节点q是不是叶子节点; 判断方法如下,首先将查询模式树节点q出栈,如果q是叶子节点,那么在数据源中对应的组Gq中节点都和q相匹配,则需要把组q中所有节点都放入栈Sq ;如果q不是叶子节点,需要首先查找节点q的所有子节点qi(i=0,…N-1)和子节点数目N,然后遍历与查询节点q相匹配的组Gq,对组的每一个节点Gq_>Current进行匹配,判断节点Gq->Current是否存在N个子节点分别和qi匹配,如果存在,说明当前节点Gq_>Current满足以q为根结点的查询模式树分支匹配,则把节点对(Gq_>Current, Gq->Current.value)放入栈Sq中,HPM式树匹配算法执行后, 所有满足子匹配的节点都放入对应的栈中。本专利技术的有益效果是:针对XML读取访问等方面存在的问题提出了一种灵活的模式树匹配算法HPM,该算法基于文中设计的一种两层的双向树索引结构HP T(High-Performance-Tree),能够在XML文档中直接找到一个查询模式树的匹配结果,不会产生无用的中间结果集,然后将中间结果集保存在堆栈中,然后通过连接运算形成最后的查询匹配结果,提高了查询匹配的成功概率。附图说明图1是一个简单的XML文档拓扑结构示例 图2是传统索引结构 图3是HPT索引结构示例 图4是HPM查询模式树; 图5是HPM堆栈示意 图6是查询模式树中间匹配栈结构示意 图7是匹配结果栈结构示例图。具体实施例方式本专利技术中两层的双向树索引结构HPT的主要实现思路为: HPT是本文中设计的一种两层的双向树索引结构,包括组层和元素层,该索引结构是一个两层树结构,组层可以提供一个简单的结构关系,元素层提供详细的子节点到父节点的连接,能够方便的找到相关节点的父节点,因此HPT是一种能够处理XML结构查询的快速索弓I。组层内的元素索引是基于组的,这样方便结构查询时根据组进行,可以去掉多余的查询空间,减少匹配次数能够提高效率和方便查询。HPT与传统的路径索引方法的同一个组内元素是无序的相比,HPT索引把具有相同路径信息的节点放到一个组内。也就是说,如果两个节点是等同的,在该索引结构中就把它们放到一个组内,这样就可以大大的提高XML数据的查询效率。本专利技术中HPM模式树匹配算法的主要实现思路为: HPM模式树匹配算法是本专利中为提高查询效率设计的一个算法。我们设定查询模式树节点q和XML数据源中节点p,如果q是叶子节点,且节点P和节点q标记相同,则称P和q相匹配;如果q是非叶子节点,同时存在节点P和以P为根结点的子树和查询模式树中节点q以及以q为根结点的子树相匹配,那么P和q相匹配。在HPM算法中,对查询模式树中的每一个节点,我们设计了一个栈和一个列表,栈用来存储和查询模式树节点相匹配的数据源中的节点集合,列表存储的是查询模式树对应的HPT中组p中的元素数组。Gpacurrent表示目前正在匹配的组中的节点。该算法基本实现流程为:给一个查询模式树和生成的数据源HPT,首先调用广度优先算法把查询模式树中的节点压栈,然后本文档来自技高网...

【技术保护点】
一种基于XML的Web数据快速查询方法,?其特征在于通过双层的双向树索引结构HPT在XML中直接找到一个查询模式树的匹配结果,所有的中间结果集在堆栈中保存起来,最终形成最后的查询匹配结果,以此提高查询匹配的成功概率,达到了快速响应用户需求的目的,具体内容如下:两层的HPT双向树索引结构,HPT是High?Performance?Tree的英文缩写,HPT双向树索引结构,包括组层和元素层,元素层提供详细的子节点到父节点的连接,能够方便的找到相关节点的父节点,因此双向树索引结构HPT是一种能够处理XML结构查询的快速索引,组层内的元素索引是基于组的,这样方便结构查询时根据组进行,去掉多余的查询空间,减少匹配次数能够提高效率和方便查询,传统的路径索引方法是同一个组内元素是无序的,而双向树索引结构HPT是把具有相同路径信息的节点放到一个组内,也就是说,如果两个节点是等同的,在该索引结构中就把它们放到一个组内,这样就能大大的提高XML数据的查询效率,HPT索引结构的定义及具体实现方式如下:HPT双向树索引结构中的每个节点g称为一个组,每个组的信息包括标识符g.id和组名称g.name,查询匹配时,根据查询模式树中节点名称和g.name进行匹配,第一,每个组包括一个元素数组g.pid[],在组中用一个数组保存组中元素的父节点信息,第二,HPT中边是有方向的,假设有边g1—>g2,那么组g1叫做组g2的父组,组g2叫做组g1的子组;第三,组g中数组g.pid[]的索引下标为k的数值表示组g中的第(k+l)个元素,g.Pid[k]的值表示组中第(k+l)个元素的父节点在组g的父组中的数组的索引位置;为了提高查询效率,减少匹配次数采用HPM模式树匹配方法进行查询模式树的匹配,HPM是High?Performance?Match的英文缩写,HPM模式树匹配方法如下:设定查询HPM模式树节点q和XML数据源中节点p,如果q是叶子节点,且节点p和节点q标记相同,则称p和q相匹配;如果q是非叶子节点,同时存在节点p和以p为根结点的子树和查询模式树中节点q以及以q为根结点的子树相匹配,那么p和q相匹配,在HPM模式树匹配方法中,对查询模式树中的每一个节点,设计一个栈和一个列表,栈用来存储和查询模式树节点相匹配的数据源中的节点集合,列表存储的是查询模式树对应的HPT中组p中的元素数组,Gpàcurrent表示目前正在匹配的组中的节点,该方法的基本实现流程为:给一个查询模式树和生成的数据源HPT,首先调用广度优先算法把查询模式树中的节点压栈,然后在栈上调用HPM模式树匹配方法,在数据源中找到与查询模式树中节点相匹配的节点,并且把结果存储在堆栈中,最后调用函数把中间结果连接起来得到与查询模式树相匹配的节点集合;HPM模式树匹配算法的具体实现方式如下:首先利用广度优先对查询模式树进行遍历,然后对遍历到的节点压栈,得到查询模式树栈S,?HPM式树匹配算法是用来查找查询模式树栈S在XML数据源中相匹配的节点,在HPM式树匹配算法中,对应一个查询模式树的q节点,Sq.value表示栈Sq中Gq.value的值集合,它表示栈Sq中元素的父节点在父组中的位置,再HPM模式树匹配算法判断查询模式树节点q是不是叶子节点;?判断方法如下,首先将查询模式树节点q出栈,如果q是叶子节点,那么在数据源中对应的组Gq中节点都和q相匹配,则需要把组q中所有节点都放入栈Sq;如果q不是叶子节点,需要首先查找节点q的所有子节点qi(i=0,…N?1)和子节点数目N,然后遍历与查询节点q相匹配的组Gq,对组的每一个节点Gq?>Current进行匹配,判断节点Gq?>Current是否存在N个子节点分别和qi匹配,如果存在,说明当前节点Gq?>Current满足以q为根结点的查询模式树分支匹配,则把节点对(Gq?>Current,Gq?>Current.value)放入栈Sq中,HPM式树匹配算法执行后,所有满足子匹配的节点都放入对应的栈中。...

【技术特征摘要】

【专利技术属性】
技术研发人员:张砚波
申请(专利权)人:浪潮电子信息产业股份有限公司
类型:发明
国别省市:

网友询问留言 已有0条评论
  • 还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。

1