一种区块链数据查询方法、系统及相关设备与流程

专利2022-06-29  71


本发明涉及区块链技术领域,尤其涉及一种区块链数据查询方法、系统及相关设备。



背景技术:

因为区块链具有防篡改、可追溯等安全特性,越来越多的行业选择使用区块链进行数据存储,例如金融行业,很多银行机构已经在信贷业务上使用区块链技术,利用区块链存储客户的授信相关的数据。

区块链特点是,每个区块链节点都保存全量的区块链数据,这样一来,如果要查询区块链数据,就必须对整个区块链上存储的信息进行遍历,查询与输入的搜索词汇匹配的区块。随着区块链数据的日益增长,这种遍历查询数据的就会影响查询效率,导致无法快速查询客户的授信数据。



技术实现要素:

本发明实施例提供了一种区块链数据查询方法、系统及相关设备,用于提高区块链数据查询的效率。

本发明实施例第一方面提供了一种区块链数据查询方法,可包括:

对目标区块链中的每个区块数据进行分词处理,得到每个区块的至少一个预设字段的字段值,并将所述预设字段的字段值作为对应区块的索引关键字加入索引数据库;

建立每个区块的唯一标识与其所属的索引关键字之间的映射关系;

接收客户端的数据查询请求,所述数据查询请求中包含查询关键字;

判断所述索引数据库中是否存在与所述查询关键字匹配的目标索引关键字,若存在,则根据所述映射关系查询所述目标索引关键字对应的区块数据。

可选的,作为一种可能的实施方式,本发明实施例中,所述区块的唯一标识包括:区块hash和/或区块高度值。

可选的,作为一种可能的实施方式,本发明实施例中,当所述目标区块链中保存的是企业授信数据时,所述预设字段包括:企业名称、企业税号、企业地址、企业联系方式、授信额度、贷款金额、贷款期限、还款方式、贷款银行中的一个或多个字段。

可选的,作为一种可能的实施方式,本发明实施例中,区块链数据查询方法还包括:

向所述客户端返回查询到的区块数据,以使得客户端显示查询到的区块数据。

本发明实施例第二方面提供了一种区块链数据查询系统,可包括:

搜索引擎模块,用于对目标区块链中的每个区块数据进行分词处理,得到每个区块的预设字段的字段值,并将所述预设字段的字段值作为对应区块的索引关键字加入索引数据库;

所述搜索引擎模块还用于建立每个区块的唯一标识与其所属的索引关键字之间的映射关系;

查询模块,用于接收客户端的数据查询请求,所述数据查询请求中包含查询关键字;

所述搜索引擎模块还用于判断所述索引数据库中是否存在与所述查询关键字匹配的目标索引关键字,若存在,则根据所述映射关系查询所述目标索引关键字对应的区块数据。

可选的,作为一种可能的实施方式,本发明实施例中,所述区块的唯一标识包括:区块hash和/或区块高度值。

可选的,作为一种可能的实施方式,本发明实施例中,当所述目标区块链中保存的是企业授信数据时,所述预设字段包括:企业名称、企业税号、企业地址、企业联系方式、授信额度、贷款金额、贷款期限、还款方式、贷款银行中的一个或多个字段。

可选的,作为一种可能的实施方式,本发明实施例中的区块链数据查询系统还可以包括:

发送模块,用于向所述客户端返回查询到的区块数据,以使得客户端显示查询到的区块数据。

本发明实施例第三方面提供了一种计算机装置,所述计算机装置包括处理器,所述处理器用于执行存储器中存储的计算机程序时实现如第一方面及第一方面中任意一种可能的实施方式中的步骤。

本发明实施例第四方面提供了一种计算机可读存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现如第一方面及第一方面中任意一种可能的实施方式中的步骤。

从以上技术方案可以看出,本发明实施例具有以下优点:

本发明实施例中,区块链数据查询系统可以对目标区块链中的每个区块数据进行分词处理,得到每个区块的至少一个预设字段的字段值,并将预设字段的字段值作为对应区块的索引关键字加入索引数据库,并建立每个区块的唯一标识与其所属的索引关键字之间的映射关系;在接收客户端的数据查询请求之后,可以判断索引数据库中是否存在与查询关键字匹配的目标索引关键字,若存在,则根据映射关系查询目标索引关键字对应的区块数据。相对于现有技术,在数据查询的过程中,无需对整个区块链中保存的所有数据进行遍历,只需对索引数据库中的索引关键字进行匹配,减少了检索数据量,提高了区块链数据查询的效率。

附图说明

图1为本发明实施例中一种区块链数据查询方法的一个实施例示意图;

图2为本发明实施例中一种区块链数据查询系统的一个实施例示意图;

图3为本发明实施例中一种计算机装置的一个实施例示意图。

具体实施方式

本发明实施例提供了一种区块链数据查询方法、系统及相关设备,用于提高区块链数据查询的效率。

为了使本技术领域的人员更好地理解本发明方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分的实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本发明保护的范围。

本发明的说明书和权利要求书及上述附图中的术语“第一”、“第二”、“第三”、“第四”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的实施例能够以除了在这里图示或描述的内容以外的顺序实施。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。

因为区块链具有防篡改、可追溯等安全特性,越来越多的行业选择使用区块链进行数据存储,例如金融行业,很多银行机构已经在信贷业务上使用区块链技术,利用区块链存储客户的授信相关的数据。区块链还有一个特点是,每个区块链节点都保存全量的区块链数据,这样一来,如果要查询区块链数据,就必须对整个区块链进行遍历处理,随着区块链数据的日益增长,就会影响查询效率,导致无法快速查询客户的授信数据。

本发明实施例通过预先对区块数据进行分词处理,创建由分词关键词与区块hash和/或区块高度值组成的索引数据库,当需要查询区块数据时,先通过匹配索引数据快速定位具体区块,再返回对应的区块数据,从而解决遍历查询区块数据效率不高的问题。

为了便于理解,下面对本发明实施例中的具体流程进行描述,请参阅图1,本发明实施例中一种区块链数据查询方法的一个实施例可包括:

101、对目标区块链中的每个区块数据进行分词处理,得到每个区块的至少一个预设字段的字段值,并将预设字段的字段值作为对应区块的索引关键字加入索引数据库;

现有方案中的数据搜索匹配是对整个区块链中的数据进行检索,费时费力。申请人注意到,用户搜索数据时,往往是基于少数的关键字进行检索查询,为此可以提前对区块中的数据进行自然语言处理,例如,对目标区块链中的每个区块数据进行分词处理,得到每个区块的至少一个预设字段的字段值(例如2个字段值或多个字段值),并将预设字段的字段值作为对应区块的索引关键字加入索引数据库。

示例性的,仅以区块链中的保存企业授信数据为例进行说明,当目标区块链中保存的是企业授信数据时,预设字段包括:企业名称、企业税号、企业地址、企业联系方式、授信额度、贷款金额、贷款期限、还款方式、贷款银行中的一个或多个字段,具体的字段选择,此处不做限定。可选的,还可以在用户界面显示预设字段,以提示用户输入对应的查询关键字,避免输入无效的字段,提高检索效率。

可以理解的是,具体的预设字段可以根据区块链中存储的数据类型和用户需要检索的数据类型进行合理的设置,具体的预设字段此处不做限定。

102、建立每个区块的唯一标识与其所属的索引关键字之间的映射关系;

在得到至少一个区块的预设字段的字段值之后,可以建立每个区块的唯一标识与其所属的索引关键字之间的映射关系。

可选的,区块的唯一标识可以包括:区块hash和/或区块高度值。示例性的,如下表1所示,当区块的唯一标识为区块hash和区块高度值时,索引关键字“a科技有限公司”和“91440111115267261y”可以同时与相同的区块hash和区块高度值建立映射关系,即相同的区块hash和区块高度值可以对应多个索引关键字。

表1

103、接收客户端的数据查询请求,数据查询请求中包含查询关键字;

在建立索引数据库及映射关系之后,区块链数据查询系统可以接收客户端的数据查询请求,数据查询请求中包含查询关键字,并处理该数据查询请求。

104、判断索引数据库中是否存在与查询关键字匹配的目标索引关键字,若存在,则根据映射关系查询目标索引关键字对应的区块数据。

当获取到数据查询请求中包含查询关键字之后,区块链数据查询系统可以判断索引数据库中是否存在与查询关键字匹配的目标索引关键字,若存在,则根据映射关系查询目标索引关键字对应的区块数据。

具体的,当索引数据库中是否存在与查询关键字相同或相似度大于预设阈值,则判定匹配成功。

本发明实施例中,区块链数据查询系统可以对目标区块链中的每个区块数据进行分词处理,得到每个区块的至少一个预设字段的字段值,并将预设字段的字段值作为对应区块的索引关键字加入索引数据库,并建立每个区块的唯一标识与其所属的索引关键字之间的映射关系;在接收客户端的数据查询请求之后,可以判断索引数据库中是否存在与查询关键字匹配的目标索引关键字,若存在,则根据映射关系查询目标索引关键字对应的区块数据。相对于现有技术,在数据查询的过程中,无需对整个区块链中保存的所有数据进行遍历,只需对索引数据库中的索引关键字进行匹配,减少了检索数据量,提高了区块链数据查询的效率。

可选的,作为一种可能的实施方式,在查询到对应的区块数据之后,区块链数据查询系统可以向所述客户端返回查询到的区块数据,以使得客户端显示查询到的区块数据。若存在多个匹配成功的区块数据,则可以显示多个匹配成功的区块数据以供用户选择,若匹配失败,则可以显示提示信息。

请参阅图2,本发明实施例中还提供了一种区块链数据查询系统,可包括:

搜索引擎模块201,用于对目标区块链中的每个区块数据进行分词处理,得到每个区块的预设字段的字段值,并将预设字段的字段值作为对应区块的索引关键字加入索引数据库;

搜索引擎模块201还用于建立每个区块的唯一标识与其所属的索引关键字之间的映射关系;

查询模块202,用于接收客户端的数据查询请求,数据查询请求中包含查询关键字;

搜索引擎模块201还用于判断索引数据库中是否存在与查询关键字匹配的目标索引关键字,若存在,则根据映射关系查询目标索引关键字对应的区块数据。

可选的,作为一种可能的实施方式,区块的唯一标识包括:区块hash和/或区块高度值。

可选的,作为一种可能的实施方式,当目标区块链中保存的是企业授信数据时,预设字段包括:企业名称、企业税号、企业地址、企业联系方式、授信额度、贷款金额、贷款期限、还款方式、贷款银行中的一个或多个字段。

可选的,作为一种可能的实施方式,区块链数据查询系统还可以包括:

发送模块,用于向客户端返回查询到的区块数据,以使得客户端显示查询到的区块数据。

所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的系统,装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。

上面从模块化功能实体的角度对本发明实施例中的区块链数据查询系统进行了描述,请参阅图3,下面从硬件处理的角度对本发明实施例中的计算机装置进行描述:

该计算机装置1可以包括存储器11、处理器12和输入输出总线13。处理器11执行计算机程序时实现上述图1所示的区块链数据查询方法实施例中的步骤,例如图1所示的步骤101至104。或者,处理器执行计算机程序时实现上述各装置实施例中各模块或单元的功能。

本发明的一些实施例中,处理器具体用于实现如下步骤:

对目标区块链中的每个区块数据进行分词处理,得到每个区块的至少一个预设字段的字段值,并将预设字段的字段值作为对应区块的索引关键字加入索引数据库;

建立每个区块的唯一标识与其所属的索引关键字之间的映射关系;

接收客户端的数据查询请求,数据查询请求中包含查询关键字;

判断索引数据库中是否存在与查询关键字匹配的目标索引关键字,若存在,则根据映射关系查询目标索引关键字对应的区块数据。

可选的,作为一种可能的实施方式,区块的唯一标识包括:区块hash和/或区块高度值。

可选的,作为一种可能的实施方式,当目标区块链中保存的是企业授信数据时,预设字段包括:企业名称、企业税号、企业地址、企业联系方式、授信额度、贷款金额、贷款期限、还款方式、贷款银行中的一个或多个字段。

可选的,作为一种可能的实施方式,处理器还可以用于实现如下步骤:

向客户端返回查询到的区块数据,以使得客户端显示查询到的区块数据。

其中,存储器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可以是外设部件互连标准(peripheralcomponentinterconnect,简称pci)总线或扩展工业标准结构(extendedindustrystandardarchitecture,简称eisa)总线等。该总线可以分为地址总线、数据总线、控制总线等。为便于表示,图3中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。

进一步地,计算机装置还可以包括有线或无线网络接口14,网络接口14可选的可以包括有线接口和/或无线接口(如wi-fi接口、蓝牙接口等),通常用于在该计算机装置1与其他电子设备之间建立通信连接。

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

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

本发明还提供了一种计算机可读存储介质,该计算机可读存储介质上存储有计算机程序,计算机程序被处理器执行时,可以实现如下步骤:

对目标区块链中的每个区块数据进行分词处理,得到每个区块的至少一个预设字段的字段值,并将预设字段的字段值作为对应区块的索引关键字加入索引数据库;

建立每个区块的唯一标识与其所属的索引关键字之间的映射关系;

接收客户端的数据查询请求,数据查询请求中包含查询关键字;

判断索引数据库中是否存在与查询关键字匹配的目标索引关键字,若存在,则根据映射关系查询目标索引关键字对应的区块数据。

可选的,作为一种可能的实施方式,区块的唯一标识包括:区块hash和/或区块高度值。

可选的,作为一种可能的实施方式,当目标区块链中保存的是企业授信数据时,预设字段包括:企业名称、企业税号、企业地址、企业联系方式、授信额度、贷款金额、贷款期限、还款方式、贷款银行中的一个或多个字段。

可选的,作为一种可能的实施方式,处理器还可以用于实现如下步骤:

向客户端返回查询到的区块数据,以使得客户端显示查询到的区块数据。

在本申请所提供的几个实施例中,应该理解到,所揭露的系统,装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。

所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。

另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。

所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:u盘、移动硬盘、只读存储器(rom,read-onlymemory)、随机存取存储器(ram,randomaccessmemory)、磁碟或者光盘等各种可以存储程序代码的介质。

以上所述,以上实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围。


技术特征:

1.一种区块链数据查询方法,其特征在于,包括:

对目标区块链中的每个区块数据进行分词处理,得到每个区块的至少一个预设字段的字段值,并将所述预设字段的字段值作为对应区块的索引关键字加入索引数据库;

建立每个区块的唯一标识与其所属的索引关键字之间的映射关系;

接收客户端的数据查询请求,所述数据查询请求中包含查询关键字;

判断所述索引数据库中是否存在与所述查询关键字匹配的目标索引关键字,若存在,则根据所述映射关系查询所述目标索引关键字对应的区块数据。

2.根据权利要求1所述的方法,其特征在于,所述区块的唯一标识包括:区块hash和/或区块高度值。

3.根据权利要求1所述的方法,其特征在于,当所述目标区块链中保存的是企业授信数据时,所述预设字段包括:企业名称、企业税号、企业地址、企业联系方式、授信额度、贷款金额、贷款期限、还款方式、贷款银行中的一个或多个字段。

4.根据权利要求1至3中任一项所述的方法,其特征在于,还包括:

向所述客户端返回查询到的区块数据,以使得客户端显示查询到的区块数据。

5.一种区块链数据查询系统,其特征在于,包括:

搜索引擎模块,用于对目标区块链中的每个区块数据进行分词处理,得到每个区块的预设字段的字段值,并将所述预设字段的字段值作为对应区块的索引关键字加入索引数据库;

所述搜索引擎模块还用于建立每个区块的唯一标识与其所属的索引关键字之间的映射关系;

查询模块,用于接收客户端的数据查询请求,所述数据查询请求中包含查询关键字;

所述搜索引擎模块还用于判断所述索引数据库中是否存在与所述查询关键字匹配的目标索引关键字,若存在,则根据所述映射关系查询所述目标索引关键字对应的区块数据。

6.根据权利要求5所述的系统,其特征在于,所述区块的唯一标识包括:区块hash和/或区块高度值。

7.根据权利要求5所述的系统,其特征在于,当所述目标区块链中保存的是企业授信数据时,所述预设字段包括:企业名称、企业税号、企业地址、企业联系方式、授信额度、贷款金额、贷款期限、还款方式、贷款银行中的一个或多个字段。

8.根据权利要求5至7中任一项所述的系统,其特征在于,还包括:

发送模块,用于向所述客户端返回查询到的区块数据,以使得客户端显示查询到的区块数据。

9.一种计算机装置,其特征在于,所述计算机装置包括处理器,所述处理器用于执行存储器中存储的计算机程序时实现如权利要求1至4中任意一项所述方法的步骤。

10.一种计算机可读存储介质,其上存储有计算机程序,其特征在于:所述计算机程序被处理器执行时实现如权利要求1至4中任意一项所述方法的步骤。

技术总结
本发明实施例提供了一种区块链数据查询方法、系统及相关设备,用于提高区块链数据查询的效率。本发明实施例方法包括:对目标区块链中的每个区块数据进行分词处理,得到每个区块的至少一个预设字段的字段值,并将所述预设字段的字段值作为对应区块的索引关键字加入索引数据库;建立每个区块的唯一标识与其所属的索引关键字之间的映射关系;接收客户端的数据查询请求,所述数据查询请求中包含查询关键字;判断所述索引数据库中是否存在与所述查询关键字匹配的目标索引关键字,若存在,则根据所述映射关系查询所述目标索引关键字对应的区块数据。

技术研发人员:钟登辉;高翔;赵彦晖
受保护的技术使用者:深圳微众信用科技股份有限公司
技术研发日:2020.01.15
技术公布日:2020.06.09

转载请注明原文地址: https://bbs.8miu.com/read-25352.html

最新回复(0)