掌桥专利:专业的专利平台
掌桥专利
首页

数据查询方法及装置

文献发布时间:2023-06-19 11:16:08


数据查询方法及装置

技术领域

本发明涉及数据查询技术领域,尤其涉及一种数据查询方法及装置。

背景技术

在传统查询SQL中使用函数时,该函数必须要预先创建好,才能在查询SQL中使用;当该函数不再需要使用时,还需要手动去删除。在查询SQL中有复杂的处理或者多次使用的处理时,把该部分封装成函数,以简化SQL。如果这些封装的函数只在当前查询SQL中使用,那么创建删除这些函数从效率和易用性上来看都存在不足的地方。此外,在只读备库上,是无法创建函数,那么这个查询SQL在只读备库上可能就无法执行或者执行的SQL非常复杂。

发明内容

有鉴于此,本发明提供一种数据查询方法及装置,避免不必要的创建删除函数的过程,减少操作步骤,提高执行效率,同时也解决了在只读备库上,无法创建查询SQL所需要的函数的问题。

一方面,本发明提供一种数据查询方法,包括:

创建包含临时函数的查询SQL语句;

解析所述临时函数得到所述临时函数的语法树,并解析所述查询SQL语句的主体得到查询语法树;

语义分析所述临时函数的语法树以及查询语法树;

根据语义分析结果执行语句,返回执行结果,并释放临时函数对象。

进一步地,语义分析所述临时函数的语法树的步骤包括:

根据临时函数的语法树在当前上下文环境中,生成临时函数的对象,把临时函数对象保存到查询语法树中。

进一步地,语义分析所述查询语法树的步骤包括:

分析所述查询语法树中函数节点的语义时,优先从所述临时函数对象中查找,在从所述临时函数对象中查找时,从系统内定义的函数中查找;

找到对应的函数对象后,把函数的相关信息保存到所述查询语法树的函数节点中。

进一步地,所述根据语义分析结果执行语句的步骤包括:

将所述查询语法树中的临时函数对象复制到执行树中保存;

需要执行函数时,根据函数节点保存的信息判断,如果是临时函数,则从执行树中获取到对应的临时函数对象;如果不是临时函数,则从系统内定义的函数中获取函数对象。

进一步地,所述释放临时函数对象的步骤包括:

通过释放查询SQL语句的上下文环境,以释放临时函数对象。

另一方面,数据查询装置,其特征在于,包括:

语句创建模块,用于创建包含临时函数的查询SQL语句;

语句解析模块,用于解析所述临时函数得到所述临时函数的语法树,并解析所述查询SQL语句的主体得到查询语法树;

语义分析模块,用于语义分析所述临时函数的语法树以及查询语法树;

语句执行模块,用于根据语义分析结果执行语句,返回执行结果,并释放临时函数对象。

进一步地,所述语义分析模块具体用于根据临时函数的语法树在当前上下文环境中,生成临时函数的对象,把临时函数对象保存到查询语法树中。

进一步地,所述语义分析模块还具体用于分析所述查询语法树中函数节点的语义时,优先从所述临时函数对象中查找,在从所述临时函数对象中查找时,从系统内定义的函数中查找;找到对应的函数对象后,把函数的相关信息保存到所述查询语法树的函数节点中。

进一步地,所述语句执行模块具体用于将所述查询语法树中的临时函数对象复制到执行树中保存;需要执行函数时,根据函数节点保存的信息判断,如果是临时函数,则从执行树中获取到对应的临时函数对象;如果不是临时函数,则从系统内定义的函数中获取函数对象。

进一步地,所述语句执行模块还具体用于通过释放查询SQL语句的上下文环境,以释放临时函数对象。

本发明数据查询方法及装置,对查询SQL中不常用的复杂计算部分或者多次使用部分,封装成临时函数,在查询SQL中定义,SQL执行完后自动删除,这样避免不必要的创建删除函数的过程,减少操作步骤,提高执行效率。同时也解决了在只读备库上,无法创建查询SQL所需要的函数的问题。

附图说明

为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其它的附图。

图1为根据本发明示例性第一实施例的数据查询方法的流程图;

图2为根据本发明示例性第二实施例的数据查询方法的流程图;

图3为根据本发明示例性第三实施例的数据查询装置的结构框图。

具体实施方式

下面结合附图对本发明实施例进行详细描述。

需说明的是,在不冲突的情况下,以下实施例及实施例中的特征可以相互组合;并且,基于本公开中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本公开保护的范围。

需要说明的是,下文描述在所附权利要求书的范围内的实施例的各种方面。应显而易见,本文中所描述的方面可体现于广泛多种形式中,且本文中所描述的任何特定结构及/或功能仅为说明性的。基于本公开,所属领域的技术人员应了解,本文中所描述的一个方面可与任何其它方面独立地实施,且可以各种方式组合这些方面中的两者或两者以上。举例来说,可使用本文中所阐述的任何数目个方面来实施设备及/或实践方法。另外,可使用除了本文中所阐述的方面中的一或多者之外的其它结构及/或功能性实施此设备及/或实践此方法。

图1为根据本发明示例性第一实施例的数据查询方法的流程图,如图1所示,本发明一种数据查询方法,包括:

步骤101:创建包含临时函数的查询SQL语句。

步骤102:解析所述临时函数得到所述临时函数的语法树,并解析所述查询SQL语句的主体得到查询语法树。

步骤103:语义分析所述临时函数的语法树以及查询语法树。

步骤104:根据语义分析结果执行语句,返回执行结果,并释放临时函数对象。

本实施例对查询SQL中不常用的复杂计算部分或者多次使用部分,封装成临时函数,在查询SQL中定义,SQL执行完后自动删除,这样避免不必要的创建删除函数的过程,减少操作步骤,提高执行效率。同时也解决了在只读备库上,无法创建查询SQL所需要的函数的问题。

图2为根据本发明示例性第二实施例的数据查询方法的流程图。图2为图1所示方法的优选实施方式。如图2所示,数据查询方法包括:

1)创建包含临时函数的查询SQL语句。

2)语法解析带临时函数的查询SQL语句,具体包括:

a)语法解析临时函数,与创建函数的语法解析处理基本一致,得到一个创建临时函数的语法树;

b)语法解析SQL主体,得到查询语法树;

3)对临时函数的语法树进行语义分析,具体包括:

a)参考创建函数的流程,根据临时函数的语法树在当前上下文环境中,生成临时函数的对象,把临时函数对象保存到查询语法树中;

4)对SQL主体的语法树进行语义分析,具体包括:

a)分析语法树中函数节点的语义时,优先从临时函数对象中查找,找不到再从系统内定义的函数中查找;

b)找到对应的(临时)函数对象后,把(临时)函数的相关信息保存到查询树的函数节点中;

5)生成执行计划,具体包括:

a)把查询树中临时函数对象复制到执行树中保存;

6)执行语句,具体包括:

a)需要执行函数时,根据函数节点保存的信息判断,如果是临时函数,则从执行树中获取到对应的临时函数对象;否则从系统内定义的函数中获取函数对象;

b)临时函数执行处理与普通函数的处理一致;

7)返回执行结果;以及释放查询SQL的上下文环境,以释放临时函数对象。

本实施例通过在查询SQL中定义临时函数,没有了函数的创建和删除过程,在使用过程中简化了操作步骤,提高了函数的执行效率。同时,临时函数的实现没有涉及到数据库的数据修改,所以完全可以在只读备库上使用带临时函数的查询SQL。

图3为根据本发明示例性第三实施例的数据查询装置的结构框图。图1及图2所示实施例可以适用于本实施例,具体如图3所示,数据查询装置包括:

语句创建模块301,用于创建包含临时函数的查询SQL语句;

语句解析模块302,用于解析所述临时函数得到所述临时函数的语法树,并解析所述查询SQL语句的主体得到查询语法树;

语义分析模块303,用于语义分析所述临时函数的语法树以及查询语法树;

语句执行模块304,用于根据语义分析结果执行语句,返回执行结果,并释放临时函数对象。

优选地,所述语义分析模块303具体用于根据临时函数的语法树在当前上下文环境中,生成临时函数的对象,把临时函数对象保存到查询语法树中。

进一步优选地,所述语义分析模块303还具体用于分析所述查询语法树中函数节点的语义时,优先从所述临时函数对象中查找,在从所述临时函数对象中查找时,从系统内定义的函数中查找;找到对应的函数对象后,把函数的相关信息保存到所述查询语法树的函数节点中。

优选地,所述语句执行模块304具体用于将所述查询语法树中的临时函数对象复制到执行树中保存;需要执行函数时,根据函数节点保存的信息判断,如果是临时函数,则从执行树中获取到对应的临时函数对象;如果不是临时函数,则从系统内定义的函数中获取函数对象。

进一步优选地,所述语句执行模块304还具体用于通过释放查询SQL语句的上下文环境,以释放临时函数对象。

本实施例通过语句创建模块301在查询SQL中定义使用的临时函数,与普通函数的创建和使用类似,主要区别是临时函数不会真正落盘,临时函数只存在于当前查询SQL的上下文环境中,当查询SQL执行完成后,语句执行模块304在清理上下文环境时会删除临时函数;这样避免不必要的创建删除函数的过程,减少操作步骤,提高执行效率。同时也解决了在只读备库上,无法创建查询SQL所需要的函数的问题。

以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到的变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应以权利要求的保护范围为准。

相关技术
  • 硬件数据库查询方法、数据库系统查询方法及装置
  • 数据库数据分片存储方法和装置、数据查询方法和装置
技术分类

06120112859688