数据查询方法、装置及计算机可读存储介质与流程

文档序号:19155444发布日期:2019-11-16 00:41阅读:167来源:国知局
数据查询方法、装置及计算机可读存储介质与流程

本发明涉及数据处理技术领域,尤其涉及一种数据查询方法、装置及计算机可读存储介质。



背景技术:

针对hbase这一开源数据库,利用hbase技术可在廉价的pcserver上搭建起大规模的结构化存储集群,虽然hbase点查速度极快,但它不支持多条件数据查询。而es(elasticsearch,弹性分布式全文搜索)是一个基于lucene的搜索服务器,虽然elasticsearch多条件查询极快,但elasticsearch不适合存储用户所有字段数据;由于elasticsearch和hbase不同交互系统之间的查询条件差异较大,因此,构建hbase对应的rowkey则需要较大的数据计算量;因此,在满足数据计算便捷的前提下,如何将elasticsearch搜索服务器与hbase数据库这两种交互系统进行结合以达到快速查询数据从而便捷地获取到相应信息,成为目前亟待解决的问题之一。



技术实现要素:

本发明提供一种数据查询方法、装置及计算机可读存储介质,其主要目的在于提供一种将elasticsearch搜索服务器与hbase数据库这两种交互系统进行结合以进行便捷、快速地查询数据的方案,提高数据查询效率。

为实现上述目的,本发明还提供一种数据查询方法,该方法包括:

接收用户触发的数据查询指令并解析,获取待查询数据对应的字段信息;

根据所述字段信息,利用elasticsearch对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息;

基于利用elasticsearch查询得到的所述特征信息,在hbase数据库中查找并获取所述特征信息对应的存储在hbase数据库中的用户数据。

可选地,所述接收用户触发的数据查询指令并解析,获取待查询数据对应的字段信息,之前还包括:

按照数据查询需求,配置elasticsearch和hbase数据库。

可选地,所述按照数据查询需求,配置elasticsearch和hbase数据库,包括:

按照数据查询需求,设置每个用户分别对应的自定义字段信息;

将自定义的所述字段信息写入hbase数据库对应的预设组件中,得到hbase数据查询组件;

将得到的所述hbase数据查询组件写入elasticsearch对应的查询字段中,并在elasticsearch中建立包含所述查询字段的索引信息。

可选地,所述按照数据查询需求,设置每个用户分别对应的自定义字段信息,包括:

根据数据查询应用场景,确定为获取用户数据所对应的待抽取的字段数量;

根据确定的所述待抽取的字段数量,从每个用户信息中抽取出所述待抽取字段数量对应的用户字段信息,并将抽取出的所述用户字段信息组成对应的自定义字段信息;

其中,所述用户字段信息包括:用户识别码、身份证号码、合同编号、投保编码以及用户年龄、性别和用户职业信息。

可选地,所述根据所述字段信息,利用elasticsearch对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息,包括:

将所述字段信息中的多个字段同时作为搜索目标,利用elasticsearch进行所有字段的多维度同时搜索;

若第一时间匹配到其中一个字段对应的唯一特征信息,则将搜索到的唯一特征信息作为所述字段信息对应的特征信息;

若第一时间匹配到其中一个字段对应的特征信息有多个,则利用elasticsearch继续搜索,直至所述字段信息中包含的所有字段均能匹配到对应的特征信息且匹配到的所述特征信息是唯一的,则将匹配到的唯一的所述特征信息作为所述字段信息对应的特征信息。

此外,为实现上述目的,本发明还提供一种数据查询装置,该装置包括存储器和处理器,所述存储器中存储有可在所述处理器上运行的数据查询程序,所述数据查询程序被所述处理器执行时实现如下步骤:

接收用户触发的数据查询指令并解析,获取待查询数据对应的字段信息;

根据所述字段信息,利用elasticsearch对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息;

基于利用elasticsearch查询得到的所述特征信息,在hbase数据库中查找并获取所述特征信息对应的存储在hbase数据库中的用户数据。

可选地,所述数据查询程序还可被所述处理器执行,以在“接收用户触发的数据查询指令并解析,获取待查询数据对应的字段信息”步骤之前,还实现如下步骤:

按照数据查询需求,配置elasticsearch和hbase数据库。

可选地,所述数据查询程序还可被所述处理器执行,以在按照数据查询需求,配置elasticsearch和hbase数据库,包括:

按照数据查询需求,设置每个用户分别对应的自定义字段信息;

将自定义的所述字段信息写入hbase数据库对应的预设组件中,得到hbase数据查询组件;

将得到的所述hbase数据查询组件写入elasticsearch对应的查询字段中,并在elasticsearch中建立包含所述查询字段的索引信息。

可选地,所述数据查询程序还可被所述处理器执行,以在根据所述字段信息,利用elasticsearch对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息,包括:

将所述字段信息中的多个字段同时作为搜索目标,利用elasticsearch进行所有字段的多维度同时搜索;

若第一时间匹配到其中一个字段对应的唯一特征信息,则将搜索到的唯一特征信息作为所述字段信息对应的特征信息;

若第一时间匹配到其中一个字段对应的特征信息有多个,则利用elasticsearch继续搜索,直至所述字段信息中包含的所有字段均能匹配到对应的特征信息且匹配到的所述特征信息是唯一的,则将匹配到的唯一的所述特征信息作为所述字段信息对应的特征信息。

此外,为实现上述目的,本发明还提供一种计算机可读存储介质,所述计算机可读存储介质上存储有数据查询程序,所述数据查询程序可被一个或者多个处理器执行,以实现如上所述的数据查询方法的步骤。

本发明提出的数据查询方法、装置及计算机可读存储介质,接收用户触发的数据查询指令并解析,获取待查询数据对应的字段信息;根据所述字段信息,利用elasticsearch对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息;基于利用elasticsearch查询得到的所述特征信息,在hbase数据库中查找并获取所述特征信息对应的存储在hbase数据库中的用户数据。本发明实施例充分利用了elasticsearch和hbase这两种系统的优点并将二者的优点进行结合,利用elasticsearch多条件查询极快这一特点,先根据待查询数据对应的字段信息通过elasticsearch快速查询得到对应的特征信息(即定位用户),再在elasticsearch定位用户后,利用hbase极快的点查速度,获取特征信息对应的用户数据(即用户的详细信息),达到了快速查询用户大量信息的目的,提高了数据查询的便捷性和数据查询的效率,节约了查询时间。

附图说明

图1为本发明一实施例提供的数据查询方法的流程示意图;

图2为本发明一实施例提供的数据查询装置的内部结构示意图;

图3为本发明一实施例提供的数据查询装置中数据查询程序的模块示意图。

本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。

具体实施方式

应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。

本发明提供一种数据查询方法。参照图1所示,为本发明一实施例提供的数据查询方法的流程示意图。该方法可以由一个装置执行,该装置可以由软件和/或硬件实现。

在本实施例中,数据查询方法包括:

步骤s10,接收用户触发的数据查询指令并解析,获取待查询数据对应的字段信息。

本发明实施例中,在结合elasticsearch可进行多条件查询极快这一特点和hbase数据库的点查速度极快的特点进行数据查询时,接收用户触发的数据查询指令并响应。

进一步地,为了提高数据查询的安全性,在接收到用户触发的数据查询指令并响应的操作时,对该数据查询指令的合法性进行校验;比如,验证触发该数据查询指令的用户身份为游客身份还是会员身份;进而根据用户身份,判断触发的该数据查询指令是否在该用户身份对应的访问权限范围内。并在验证该数据查询指令合法的情况下,对该数据查询指令进行解析,并根据解析结果,获取该数据查询指令对应的待查询数据的字段信息。

步骤s20,根据所述字段信息,利用elasticsearch对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息。

步骤s30,基于利用elasticsearch查询得到的所述特征信息,在hbase数据库中查找并获取所述特征信息对应存储在hbase数据库中的用户数据。

本发明实施例中描述的elasticsearch(es,弹性分布式全文搜索)是一个基于lucene的搜索服务器,它提供了一个分布式多用户能力的全文搜索引擎,支持restfulweb、java接口,能够支持实时搜索,具有稳定、可靠、快速、安装使用方便等特点,虽然elasticsearch不适合存储用户对应的所有字段数据,但elasticsearch具备多条件查询极快的优势。因此,可以根据获取的待查询数据对应的字段信息,利用elasticsearch采用多条件查询的方式,对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息。

而hbase数据库不同于一般的关系数据库,hbase数据库是一个分布式的、面向列的开源数据库,适合非结构化数据存储;且hbase数据库是基于列的而不是基于行的数据存储模式,是一个高可靠性、高性能、面向列、可伸缩的分布式存储系统,利用hbase技术可在廉价pcserver上搭建起大规模结构化存储集群。因此,根据elasticsearch查询得到的所述特征信息,可以直接在hbase数据库中查找并获取上述特征信息对应的在所述hbase数据中存储的用户数据。

本实施例提出的数据查询方法,接收用户触发的数据查询指令并解析,获取待查询数据对应的字段信息;根据所述字段信息,利用elasticsearch对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息;基于利用elasticsearch查询得到的所述特征信息,在hbase数据库中查找并获取所述特征信息对应的存储在hbase数据库中的用户数据。本发明实施例充分利用了elasticsearch和hbase这两种系统的优点并将二者的优点进行结合,利用elasticsearch多条件查询极快这一特点,先根据待查询数据对应的字段信息通过elasticsearch快速查询得到对应的特征信息(即定位用户),再在elasticsearch定位用户后,利用hbase极快的点查速度,获取特征信息对应的用户数据(即用户的详细信息),达到了快速查询用户大量信息的目的,提高了数据查询的便捷性和数据查询的效率,节约了查询时间。

进一步地,在本发明方法的另一实施例中,该数据查询方法在图1所述实施例中的步骤s10,接收用户触发的数据查询指令并解析,获取待查询数据对应的字段信息,之前还包括如下步骤:

按照数据查询需求,配置elasticsearch和hbase数据库。

本发明实施例中,在首次执行该数据查询方法,或者针对不同的应用场景实施该数据查询方法且对应的应用场景对数据查询有特殊要求的情况下,需要对elasticsearch和hbase数据库根据数据查询的具体需求,进行相应的配置。

进一步地,在一个实施例中,按照数据查询需求,配置elasticsearch和hbase数据库,可以按照如下描述的技术手段进行实施:

按照数据查询需求,设置每个用户分别对应的自定义字段信息;

将自定义的所述字段信息写入hbase数据库对应的预设组件中,得到hbase数据查询组件;

将得到的所述hbase数据查询组件写入elasticsearch对应的查询字段中,并在elasticsearch中建立包含所述查询字段的索引信息。

本发明实施例中,在对elasticsearch和hbase进行配置时,根据数据查询请求,自定义每个用户分别对应的字段信息,并将相应的自定义字段信息分别写入hbase和elasticsearch中,在写入的过程中,先写hbase后写elasticsearch。在一个具体的应用场景中,对hbase和elasticsearch写入自定义字段信息时,先将自定义字段写入hbase数据库对应的预设组件中,得到hbase数据查询组件;然后,再将写好的hbase数据查询组件写入并保存在elasticsearch对应的查询字段中,并在elasticsearch中建立包含所述查询字段的索引信息,以便进行数据查询和检索。

对配置完成的hbase数据库和elasticsearch,在执行图1所述实施例描述的数据查询操作事件时,根据数据查询指令,首先利用elasticsearch的多条件快速查询,快速定位用户;并在elasticsearch定位用户后,即可再通过hbase的快速点查,获取hbase数据库中对应存储的用户的详细信息。

进一步地,在一个实施例中,按照数据查询需求,设置每个用户分别对应的自定义字段信息,可以按照如下技术手段实施:

根据数据查询应用场景,确定为获取用户数据所对应的待抽取的字段数量;

根据确定的所述待抽取的字段数量,从每个用户信息中抽取出所述待抽取字段数量对应的用户字段信息,并将抽取出的所述用户字段信息组成对应的自定义字段信息;

其中,所述用户字段信息包括:用户识别码、身份证号码、合同编号、投保编码以及用户年龄、性别和用户职业信息。

本发明实施例中,可以根据hbase数据库进行数据查询的具体应用场景,来设置每个用户分别对应的自定义的字段信息;不同的应用场景以及同一应用场景的不用场景需求,所需的用户的自定义字段信息均可能不同,因此,可以按需配置不同的自定义字段信息。其中,在一个具体的应用场景中,本发明实施例所描述的用户字段信息包括但不限于:用户识别码、身份证号码、合同编号、投保编码、用户年龄、用户性别、用户工作年限、用户家庭成员信息、用户在预设时长内的身体健康状况信息以及用户职业信息、用户收入信息、用户家庭资产配置信息等;且每一个用户字段信息对应的字段数量即为一个;比如,用户识别码、身份证号码、合同编号这些用户字段信息对应的字段数量即为3个。

在实际使用时,可以根据具体的应用场景、场景需求待查询数据量、查询速度和查询精度的具体要求等,来具体确定待抽取的字段数量;进而根据确定的上述待抽取的字段数量,抽取出对应的用户字段信息,从而组成所述自定义字段信息。例如,在某一具体的应用场景中,从同一用户对应的一千个字段信息中,抽取出一百个字段信息作为该用户对应的自定义字段信息等。

利用上述处理方式配置的elasticsearch和hbase数据库,为快速准确地进行数据查询提供了重要保障。

进一步地,在一个实施例中,图1所述实施例中的步骤s20,根据所述字段信息,利用elasticsearch对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息,可以按照如下技术手段实施:

将所述字段信息中的多个字段同时作为搜索目标,利用elasticsearch进行所有字段的多维度同时搜索;

若第一时间匹配到其中一个字段对应的唯一特征信息,则将搜索到的唯一特征信息作为所述字段信息对应的特征信息;

若第一时间匹配到其中一个字段对应的特征信息有多个,则利用elasticsearch继续搜索,直至所述字段信息中包含的所有字段均能匹配到对应的特征信息且匹配到的所述特征信息是唯一的,则将匹配到的唯一的所述特征信息作为所述字段信息对应的特征信息。

本发明实施例中,由于利用elasticsearch同时进行多条件快速搜索和查询时,用于进行数据搜索的字段信息中通常都可能包括多个字段,而不同的字段可能匹配到的特征信息可能唯一也可能有多个;比如,若将用户身份证号码或者用户投保号码或者用户合同编号等具备唯一属性且唯一对应一个用户的字段进行特征信息的匹配搜索时,能够在第一时间匹配到唯一对应的特征信息,则此时无需再浪费时间进行其他字段的继续匹配查找,直接将找到的特征信息作为上述字段信息对应的特征信息即可。若将用户的年龄、职业、性别等不具备唯一属性的字段进行特征信息的匹配搜索时,能够在第一时间匹配到的特征信息可能有多个,则利用elasticsearch的多条件查询,继续进行匹配,直至上述字段信息匹配的特征信息有唯一一个且该字段信息中的所有字段均能够与该特征信息进行匹配,则确定将唯一匹配到的特征信息作为上述字段信息对应的用户的特征信息。

需要进行说明的是,本发明实施例中,在利用elasticsearch进行多条件查询时,与字段信息相匹配的特征信息是唯一确定的,但该特征信息对应的用户信息可能存在多个。

本发明实施例利用elasticsearch进行多条件查询,提高了数据查询的效率和数据查询的便捷性,同时也降低数据处理的冗余量。

本发明还提供一种数据查询装置。参照图2所示,为本发明一实施例提供的数据查询装置的内部结构示意图。

在本实施例中,数据查询装置1可以是pc(personalcomputer,个人电脑),也可以是智能手机、平板电脑、便携计算机等终端设备。该数据查询装置1至少包括存储器11、处理器12,通信总线13,以及网络接口14。

其中,存储器11至少包括一种类型的可读存储介质,所述可读存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,sd或dx存储器等)、磁性存储器、磁盘、光盘等。存储器11在一些实施例中可以是数据查询装置1的内部存储单元,例如该数据查询装置1的硬盘。存储器11在另一些实施例中也可以是数据查询装置1的外部存储设备,例如数据查询装置1上配备的插接式硬盘,智能存储卡(smartmediacard,smc),安全数字(securedigital,sd)卡,闪存卡(flashcard)等。进一步地,存储器11还可以既包括数据查询装置1的内部存储单元也包括外部存储设备。存储器11不仅可以用于存储安装于数据查询装置1的应用软件及各类数据,例如数据查询程序01的代码等,还可以用于暂时地存储已经输出或者将要输出的数据。

处理器12在一些实施例中可以是一中央处理器(centralprocessingunit,cpu)、控制器、微控制器、微处理器或其他数据处理芯片,用于运行存储器11中存储的程序代码或处理数据,例如执行数据查询程序01等。

通信总线13用于实现这些组件之间的连接通信。

网络接口14可选的可以包括标准的有线接口、无线接口(如wi-fi接口),通常用于在该装置1与其他电子设备之间建立通信连接。

可选地,该装置1还可以包括用户接口,用户接口可以包括显示器(display)、输入单元比如键盘(keyboard),可选的用户接口还可以包括标准的有线接口、无线接口。可选地,在一些实施例中,显示器可以是led显示器、液晶显示器、触控式液晶显示器以及oled(organiclight-emittingdiode,有机发光二极管)触摸器等。其中,显示器也可以适当的称为显示屏或显示单元,用于显示在数据查询装置1中处理的信息以及用于显示可视化的用户界面。

图2仅示出了具有组件11-14以及数据查询程序01的数据查询装置1,本领域技术人员可以理解的是,图1示出的结构并不构成对数据查询装置1的限定,可以包括比图示更少或者更多的部件,或者组合某些部件,或者不同的部件布置。

在图2所示的装置1实施例中,存储器11中存储有数据查询程序01;处理器12执行存储器11中存储的数据查询程序01时实现如下步骤:

接收用户触发的数据查询指令并解析,获取待查询数据对应的字段信息。

本发明实施例中,在结合elasticsearch可进行多条件查询极快这一特点和hbase数据库的点查速度极快的特点进行数据查询时,接收用户触发的数据查询指令并响应。

进一步地,为了提高数据查询的安全性,在接收到用户触发的数据查询指令并响应的操作时,对该数据查询指令的合法性进行校验;比如,验证触发该数据查询指令的用户身份为游客身份还是会员身份;进而根据用户身份,判断触发的该数据查询指令是否在该用户身份对应的访问权限范围内。并在验证该数据查询指令合法的情况下,对该数据查询指令进行解析,并根据解析结果,获取该数据查询指令对应的待查询数据的字段信息。

步骤s20,根据所述字段信息,利用elasticsearch对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息。

步骤s30,基于利用elasticsearch查询得到的所述特征信息,在hbase数据库中查找并获取所述特征信息对应存储在hbase数据库中的用户数据。

本发明实施例中描述的elasticsearch(es,弹性分布式全文搜索)是一个基于lucene的搜索服务器,它提供了一个分布式多用户能力的全文搜索引擎,支持restfulweb、java接口,能够支持实时搜索,具有稳定、可靠、快速、安装使用方便等特点,虽然elasticsearch不适合存储用户对应的所有字段数据,但elasticsearch具备多条件查询极快的优势。因此,可以根据获取的待查询数据对应的字段信息,利用elasticsearch采用多条件查询的方式,对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息。

而hbase数据库不同于一般的关系数据库,hbase数据库是一个分布式的、面向列的开源数据库,适合非结构化数据存储;且hbase数据库是基于列的而不是基于行的数据存储模式,是一个高可靠性、高性能、面向列、可伸缩的分布式存储系统,利用hbase技术可在廉价pcserver上搭建起大规模结构化存储集群。因此,根据elasticsearch查询得到的所述特征信息,可以直接在hbase数据库中查找并获取上述特征信息对应的在所述hbase数据中存储的用户数据。

本实施例提出的数据查询装置,接收用户触发的数据查询指令并解析,获取待查询数据对应的字段信息;根据所述字段信息,利用elasticsearch对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息;基于利用elasticsearch查询得到的所述特征信息,在hbase数据库中查找并获取所述特征信息对应的存储在hbase数据库中的用户数据。本发明实施例充分利用了elasticsearch和hbase这两种系统的优点并将二者的优点进行结合,利用elasticsearch多条件查询极快这一特点,先根据待查询数据对应的字段信息通过elasticsearch快速查询得到对应的特征信息(即定位用户),再在elasticsearch定位用户后,利用hbase极快的点查速度,获取特征信息对应的用户数据(即用户的详细信息),达到了快速查询用户大量信息的目的,提高了数据查询的便捷性和数据查询的效率,节约了查询时间。

进一步地,在本发明方法的另一实施例中,所述数据查询程序还可被所述处理器执行,以在“接收用户触发的数据查询指令并解析,获取待查询数据对应的字段信息”步骤之前,还实现如下步骤:

按照数据查询需求,配置elasticsearch和hbase数据库。

本发明实施例中,在首次执行该数据查询方法,或者针对不同的应用场景实施该数据查询方法且对应的应用场景对数据查询有特殊要求的情况下,需要对elasticsearch和hbase数据库根据数据查询的具体需求,进行相应的配置。

进一步地,在一个实施例中,所述数据查询程序还可被所述处理器执行,以在按照数据查询需求,配置elasticsearch和hbase数据库,包括:

按照数据查询需求,设置每个用户分别对应的自定义字段信息;

将自定义的所述字段信息写入hbase数据库对应的预设组件中,得到hbase数据查询组件;

将得到的所述hbase数据查询组件写入elasticsearch对应的查询字段中,并在elasticsearch中建立包含所述查询字段的索引信息。

本发明实施例中,在对elasticsearch和hbase进行配置时,根据数据查询请求,自定义每个用户分别对应的字段信息,并将相应的自定义字段信息分别写入hbase和elasticsearch中,在写入的过程中,先写hbase后写elasticsearch。在一个具体的应用场景中,对hbase和elasticsearch写入自定义字段信息时,先将自定义字段写入hbase数据库对应的预设组件中,得到hbase数据查询组件;然后,再将写好的hbase数据查询组件写入并保存在elasticsearch对应的查询字段中,并在elasticsearch中建立包含所述查询字段的索引信息,以便进行数据查询和检索。

对配置完成的hbase数据库和elasticsearch,在执行图1所述实施例描述的数据查询操作事件时,根据数据查询指令,首先利用elasticsearch的多条件快速查询,快速定位用户;并在elasticsearch定位用户后,即可再通过hbase的快速点查,获取hbase数据库中对应存储的用户的详细信息。

进一步地,在一个实施例中,所述数据查询程序还可被所述处理器执行,以在按照数据查询需求,设置每个用户分别对应的自定义字段信息,包括:

根据数据查询应用场景,确定为获取用户数据所对应的待抽取的字段数量;

根据确定的所述待抽取的字段数量,从每个用户信息中抽取出所述待抽取字段数量对应的用户字段信息,并将抽取出的所述用户字段信息组成对应的自定义字段信息;

其中,所述用户字段信息包括:用户识别码、身份证号码、合同编号、投保编码以及用户年龄、性别和用户职业信息。

本发明实施例中,可以根据hbase数据库进行数据查询的具体应用场景,来设置每个用户分别对应的自定义的字段信息;不同的应用场景以及同一应用场景的不用场景需求,所需的用户的自定义字段信息均可能不同,因此,可以按需配置不同的自定义字段信息。其中,在一个具体的应用场景中,本发明实施例所描述的用户字段信息包括但不限于:用户识别码、身份证号码、合同编号、投保编码、用户年龄、用户性别、用户工作年限、用户家庭成员信息、用户在预设时长内的身体健康状况信息以及用户职业信息、用户收入信息、用户家庭资产配置信息等;且每一个用户字段信息对应的字段数量即为一个;比如,用户识别码、身份证号码、合同编号这些用户字段信息对应的字段数量即为3个。

在实际使用时,可以根据具体的应用场景、场景需求待查询数据量、查询速度和查询精度的具体要求等,来具体确定待抽取的字段数量;进而根据确定的上述待抽取的字段数量,抽取出对应的用户字段信息,从而组成所述自定义字段信息。例如,在某一具体的应用场景中,从同一用户对应的一千个字段信息中,抽取出一百个字段信息作为该用户对应的自定义字段信息等。

利用上述处理方式配置的elasticsearch和hbase数据库,为快速准确地进行数据查询提供了重要保障。

进一步地,在一个实施例中,所述数据查询程序还可被所述处理器执行,以在根据所述字段信息,利用elasticsearch对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息,包括:

将所述字段信息中的多个字段同时作为搜索目标,利用elasticsearch进行所有字段的多维度同时搜索;

若第一时间匹配到其中一个字段对应的唯一特征信息,则将搜索到的唯一特征信息作为所述字段信息对应的特征信息;

若第一时间匹配到其中一个字段对应的特征信息有多个,则利用elasticsearch继续搜索,直至所述字段信息中包含的所有字段均能匹配到对应的特征信息且匹配到的所述特征信息是唯一的,则将匹配到的唯一的所述特征信息作为所述字段信息对应的特征信息。

本发明实施例中,由于利用elasticsearch同时进行多条件快速搜索和查询时,用于进行数据搜索的字段信息中通常都可能包括多个字段,而不同的字段可能匹配到的特征信息可能唯一也可能有多个;比如,若将用户身份证号码或者用户投保号码或者用户合同编号等具备唯一属性且唯一对应一个用户的字段进行特征信息的匹配搜索时,能够在第一时间匹配到唯一对应的特征信息,则此时无需再浪费时间进行其他字段的继续匹配查找,直接将找到的特征信息作为上述字段信息对应的特征信息即可。若将用户的年龄、职业、性别等不具备唯一属性的字段进行特征信息的匹配搜索时,能够在第一时间匹配到的特征信息可能有多个,则利用elasticsearch的多条件查询,继续进行匹配,直至上述字段信息匹配的特征信息有唯一一个且该字段信息中的所有字段均能够与该特征信息进行匹配,则确定将唯一匹配到的特征信息作为上述字段信息对应的用户的特征信息。

需要进行说明的是,本发明实施例中,在利用elasticsearch进行多条件查询时,与字段信息相匹配的特征信息是唯一确定的,但该特征信息对应的用户信息可能存在多个。

本发明实施例利用elasticsearch进行多条件查询,提高了数据查询的效率和数据查询的便捷性,同时也降低数据处理的冗余量。

可选地,在其他实施例中,数据查询程序01还可以被分割为一个或者多个模块,一个或者多个模块被存储于存储器11中,并由一个或多个处理器(本实施例为处理器12)所执行以完成本发明,本发明所称的模块是指能够完成特定功能的一系列计算机程序指令段,用于描述数据查询程序在数据查询装置中的执行过程。

例如,参照图3所示,为本发明数据查询装置一实施例中的数据查询程序的程序模块示意图,该实施例中,数据查询程序可以被分割为指令解析模块10、es搜索模块20和hbase查询模块30,示例性地:

指令解析模块10用于:接收用户触发的数据查询指令并解析,获取待查询数据对应的字段信息;

es搜索模块20用于:根据所述字段信息,利用elasticsearch对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息;

hbase查询模块30用于:基于利用elasticsearch查询得到的所述特征信息,在hbase数据库中查找并获取所述特征信息对应的存储在hbase数据库中的用户数据。

上述指令解析模块10、es搜索模块20和hbase查询模块30等程序模块被执行时所实现的功能或操作步骤与上述实施例大体相同,在此不再赘述。

此外,本发明实施例还提出一种计算机可读存储介质,所述计算机可读存储介质上存储有数据查询程序,所述数据查询程序可被一个或多个处理器执行,以实现如下操作:

接收用户触发的数据查询指令并解析,获取待查询数据对应的字段信息;

根据所述字段信息,利用elasticsearch对所述字段信息进行数据搜索,获取所述字段信息对应的特征信息;

基于利用elasticsearch查询得到的所述特征信息,在hbase数据库中查找并获取所述特征信息对应的存储在hbase数据库中的用户数据。

本发明计算机可读存储介质具体实施方式与上述数据查询装置和方法各实施例基本相同,在此不作累述。

需要说明的是,上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。并且本文中的术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、装置、物品或者方法不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、装置、物品或者方法所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、装置、物品或者方法中还存在另外的相同要素。

通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在如上所述的一个存储介质(如rom/ram、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,或者网络设备等)执行本发明各个实施例所述的方法。

以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1