CN115168362A - 数据处理方法、装置、可读介质及电子设备 - Google Patents

数据处理方法、装置、可读介质及电子设备 Download PDF

Info

Publication number
CN115168362A
CN115168362A CN202210880610.XA CN202210880610A CN115168362A CN 115168362 A CN115168362 A CN 115168362A CN 202210880610 A CN202210880610 A CN 202210880610A CN 115168362 A CN115168362 A CN 115168362A
Authority
CN
China
Prior art keywords
target
data
key
index
query
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202210880610.XA
Other languages
English (en)
Inventor
刘洋
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Douyin Vision Co Ltd
Original Assignee
Douyin Vision Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Douyin Vision Co Ltd filed Critical Douyin Vision Co Ltd
Priority to CN202210880610.XA priority Critical patent/CN115168362A/zh
Publication of CN115168362A publication Critical patent/CN115168362A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/22Indexing; Data structures therefor; Storage structures
    • G06F16/2282Tablespace storage structures; Management thereof
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/24Querying
    • G06F16/245Query processing
    • G06F16/2455Query execution
    • G06F16/24553Query execution of query operations

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • Computational Linguistics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本公开涉及一种数据处理方法、装置、可读介质及电子设备。所述方法包括:接收数据查询指令,所述数据查询指令包括用于查询数据的目标查询方式、目标查询标识和目标属性信息;按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键;从用于存储数据的宽表中确定出与所述目标键对应的目标数据,所述宽表基于强一致性的分布式键值存储模型进行数据存储。这样,通过宽表存储的方式,能够保证同业务的数据存储在同一宽表中,解决了大型分布式系统中的数据不一致、元信息管理困难等问题,并且,基于底层的键值存储模型和强一致特性,能够提供扩展性强、功能丰富的数据服务,以应对数据存储、查询等需求。

Description

数据处理方法、装置、可读介质及电子设备
技术领域
本公开涉及计算机技术领域,具体地,涉及一种数据处理方法、装置、可读介质及电子设备。
背景技术
随着互联网技术中业务复杂度的增长和业务数量的扩张,业务研发往往面对着数据元信息难以管理、数据规模爆炸等难题,影响软件开发效率,增加数据运维难度。此时,若仍采用传统的关系型数据库的数据存储方式,由于传统关系型数据库自身的限制(例如,MySQL限制一行数据最多4096列),业务通常需要拆分数据模型,将数据存放在不同的表甚至不同的数据库中,这样,海量数据将分散在异构的各种存储系统中,难以保障读写的一致性。并且,由于各种业务都维护了自身的数据元信息,导致数据属性的读写权限管理混乱,不仅无法做到按需读取,还易造成安全隐患。因此,传统的关系型数据库存在分布式扩展性差、分布式一致性难以保障、单条记录过大导致的读写性能下降等诸多问题。此外,传统的数据库不支持复杂业务所需语义,业务需要自行开发,而不同的业务在操作各自的业务数据时,都需要实现一些相似的业务语义,如索引、缓存、分布式事务支持等,如果每个业务都实现自己的数据层,还存在工作量冗余的问题。
发明内容
提供该发明内容部分以便以简要的形式介绍构思,这些构思将在后面的具体实施方式部分被详细描述。该发明内容部分并不旨在标识要求保护的技术方案的关键特征或必要特征,也不旨在用于限制所要求的保护的技术方案的范围。
第一方面,本公开提供一种数据处理方法,所述方法包括:
接收数据查询指令,所述数据查询指令包括用于查询数据的目标查询方式、目标查询标识和目标属性信息;
按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键;
从用于存储数据的宽表中确定出与所述目标键对应的目标数据,所述宽表基于强一致性的分布式键值存储模型进行数据存储。
第二方面,本公开提供一种数据处理装置,所述装置包括:
接收模块,用于接收数据查询指令,所述数据查询指令包括用于查询数据的目标查询方式、目标查询标识和目标属性信息;
第一拼接模块,用于按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键;
第一确定模块,用于从用于存储数据的宽表中确定出与所述目标键对应的目标数据,所述宽表基于强一致性的分布式键值存储模型进行数据存储。
第三方面,本公开提供一种计算机可读介质,其上存储有计算机程序,该程序被处理装置执行时实现本公开第一方面所述方法的步骤。
第四方面,本公开提供一种电子设备,包括:
存储装置,其上存储有计算机程序;
处理装置,用于执行所述存储装置中的所述计算机程序,以实现本公开第一方面所述方法的步骤。
通过上述技术方案,接收数据查询指令,数据查询指令包括用于查询数据的目标查询方式、目标查询标识和目标属性信息,按照与目标查询方式对应的键拼接规则,对目标查询标识和目标属性信息进行拼接,得到目标键,再从用于存储数据的宽表中确定出与目标键对应的目标数据,所述宽表基于强一致性的分布式键值存储模型进行数据存储。由此,针对数据的查询需求,能够根据查询特性,生成用于在宽表中进行数据查询的目标键,从而,能够准确、快速地从宽表中定位到用户查询的相应数据。这样,通过宽表存储的方式,能够保证同业务的数据存储在同一宽表中,解决了大型分布式系统中的数据不一致、元信息管理困难等问题,并且,基于底层的键值存储模型和强一致特性,能够提供扩展性强、功能丰富的数据服务,以应对数据存储、查询等需求。
本公开的其他特征和优点将在随后的具体实施方式部分予以详细说明。
附图说明
结合附图并参考以下具体实施方式,本公开各实施例的上述和其他特征、优点及方面将变得更加明显。贯穿附图中,相同或相似的附图标记表示相同或相似的元素。应当理解附图是示意性的,原件和元素不一定按照比例绘制。在附图中:
图1是根据本公开的一种实施方式提供的数据处理方法的流程图;
图2是根据本公开提供的数据处理方法中,宽表模型的一种示例性的示意图;
图3是根据本公开的一种实施方式提供的数据处理装置的框图;
图4示出了适于用来实现本公开实施例的电子设备的结构示意图。
具体实施方式
下面将参照附图更详细地描述本公开的实施例。虽然附图中显示了本公开的某些实施例,然而应当理解的是,本公开可以通过各种形式来实现,而且不应该被解释为限于这里阐述的实施例,相反提供这些实施例是为了更加透彻和完整地理解本公开。应当理解的是,本公开的附图及实施例仅用于示例性作用,并非用于限制本公开的保护范围。
应当理解,本公开的方法实施方式中记载的各个步骤可以按照不同的顺序执行,和/或并行执行。此外,方法实施方式可以包括附加的步骤和/或省略执行示出的步骤。本公开的范围在此方面不受限制。
本文使用的术语“包括”及其变形是开放性包括,即“包括但不限于”。术语“基于”是“至少部分地基于”。术语“一个实施例”表示“至少一个实施例”;术语“另一实施例”表示“至少一个另外的实施例”;术语“一些实施例”表示“至少一些实施例”。其他术语的相关定义将在下文描述中给出。
需要注意,本公开中提及的“第一”、“第二”等概念仅用于对不同的装置、模块或单元进行区分,并非用于限定这些装置、模块或单元所执行的功能的顺序或者相互依存关系。
需要注意,本公开中提及的“一个”、“多个”的修饰是示意性而非限制性的,本领域技术人员应当理解,除非在上下文另有明确指出,否则应该理解为“一个或多个”。
本公开实施方式中的多个装置之间所交互的消息或者信息的名称仅用于说明性的目的,而并不是用于对这些消息或信息的范围进行限制。
可以理解的是,在使用本公开各实施例公开的技术方案之前,均应当依据相关法律法规通过恰当的方式对本公开所涉及个人信息的类型、使用范围、使用场景等告知用户并获得用户的授权。
例如,在响应于接收到用户的主动请求时,向用户发送提示信息,以明确地提示用户,其请求执行的操作将需要获取和使用到用户的个人信息。从而,使得用户可以根据提示信息来自主地选择是否向执行本公开技术方案的操作的电子设备、应用程序、服务器或存储介质等软件或硬件提供个人信息。
作为一种可选的但非限定性的实现方式,响应于接收到用户的主动请求,向用户发送提示信息的方式例如可以是弹窗的方式,弹窗中可以以文字的方式呈现提示信息。此外,弹窗中还可以承载供用户选择“同意”或者“不同意”向电子设备提供个人信息的选择控件。
可以理解的是,上述通知和获取用户授权过程仅是示意性的,不对本公开的实现方式构成限定,其它满足相关法律法规的方式也可应用于本公开的实现方式中。
同时,可以理解的是,本技术方案所涉及的数据(包括但不限于数据本身、数据的获取或使用)应当遵循相应法律法规及相关规定的要求。
图1是根据本公开的一种实施方式提供的数据处理方法的流程图。如图1所示,本公开提供的方法可以包括步骤11~步骤13。
在步骤11中,接收数据查询指令。
其中,数据查询指令可以包括用于查询数据的目标查询方式、目标查询标识和目标属性信息。
在步骤12中,按照与目标查询方式对应的键拼接规则,对目标查询标识和目标属性信息进行拼接,得到目标键。
在步骤13中,从用于存储数据的宽表中确定出与目标键对应的目标数据。
其中,用于存储数据的宽表是基于强一致性的分布式键值存储模型进行数据存储的。
通过上述技术方案,接收数据查询指令,数据查询指令包括用于查询数据的目标查询方式、目标查询标识和目标属性信息,按照与目标查询方式对应的键拼接规则,对目标查询标识和目标属性信息进行拼接,得到目标键,再从用于存储数据的宽表中确定出与目标键对应的目标数据,所述宽表基于强一致性的分布式键值存储模型进行数据存储。由此,针对数据的查询需求,能够根据查询特性,生成用于在宽表中进行数据查询的目标键,从而,能够准确、快速地从宽表中定位到用户查询的相应数据。这样,通过宽表存储的方式,能够保证同业务的数据存储在同一宽表中,解决了大型分布式系统中的数据不一致、元信息管理困难等问题,并且,基于底层的键值存储模型和强一致特性,能够提供扩展性强、功能丰富的数据服务,以应对数据存储、查询等需求。
为了使本领域技术人员更加理解本发明实施例提供的技术方案,下面对上文中的相应步骤进行详细的说明。
在介绍本公开的各个步骤之前,首先对本公开中宽表的生成方式进行解释说明。
本公开的数据存储使用宽表,即采用大宽表的数据模型,大宽表数据模型没有属性数量上的限制,能够将同一个领域(例如,作者和内容)的数据存放在同一个个数据库表中。示例地,大宽表模型的示意图可以如图2所示,其中UID表示用户ID(Identitydocument,唯一编码),GID表示用户组ID,通过大宽表模型能够将图2中左、右两侧的数据都存储到图2中间的宽表中。
在本公开中,宽表的底层存储是强一致性的分布式键值数据库,数据在宽表中以实体(Entity)的最小单位存储,每个实体由唯一ID标识,并记录有注册在元信息服务中的各属性的值。
在一种可能的实施方式中,本公开的宽表中的数据可以通过如下方式存储:
获取待存储数据的数据标识信息、数据类型、属性名称和属性值;
按照用于存储实体的实体键拼接规则,得到目标实体键;
在宽表中,将目标实体键与待存储数据的属性值关联存储。
其中,待存储数据相当于上文所述的实体,数据标识信息用于唯一标识待存储数据,数据类型为待存储数据的数据类型,属性名称和属性值成对存在,并且,可以存在多对属性名称和属性值,每一对属性名称和属性值均按照同样的方式进行存储。
按照实体键拼接规则得到的目标实体键是待存储数据的全局唯一键(key)。示例地,用于存储实体的实体键拼接规则可以为从前到后依次将数据标识信息、数据类型和属性名称进行拼接。
举例来说,若待存储数据的数据标识信息为101,注册有attr_1和attr_2两个属性,且属性attr_1对应的属性值为val_1,属性attr_2对应的属性值为val_2,则会分别生成对应于属性attr_1的目标实体键以及对应于属性attr_2的目标实体键。假设实体键拼接规则可以为从前到后依次将数据标识信息、数据类型和属性名称进行拼接,则对应于属性attr_1的目标实体键可以为101.ent.attr_1,对应于属性attr_2的目标实体键可以为101.ent.attr_2,从而,可以在本公开提供的宽表中,将目标实体键101.ent.attr_1与属性值val_1关联存储,并将目标实体键101.ent.attr_2与属性值val_2关联存储。
在另一种可能的实施方式中,宽表中的数据还可以通过如下方式存储:
响应于接收到针对待存储数据的非唯一索引键配置指令,确定第一索引标识信息和第一索引属性值;
按照非唯一索引键拼接规则,对第一索引标识信息、第一索引属性值和待存储数据的数据标识信息进行拼接,得到目标非唯一索引键;
在宽表中,将目标非唯一索引键与预设值关联存储。
其中,索引属性值是指期望索引的某个属性的属性值。示例地,预设值可以为空值。
示例地,非唯一索引键拼接规则可以为从前到后依次将第一索引标识信息、第一索引属性值和待存储数据的数据标识信息进行拼接,以得到目标非唯一索引键。
若需对某个属性的指定属性值配置非唯一索引键,可以将符合该属性值的所有实体分别按照非唯一索引键拼接规则进行拼接。举例来说,若索引标识信息为233,属性user_id的100这一属性值生成非唯一索引键,假设user_id为100的用户共发布了3篇文章,文章的标识信息分别为123、124和125,那么生成的目标非唯一索引键可以分别为233.100.123、233.100.124、233.100.125。之后,可以将上述三个目标非唯一索引键分别与预设值关联存储于宽表中。这样,在后续的查询过程中,就可以查找到user_id为100的用户发表过的全部文章。
另外,非唯一索引还可以实现多属性联合索引,用于实现数据关系语义、假设第一索引标识信息101,由属性attr_1和attr_2联合索引,若建立属性值attr_value_1(属性attr_1的属性值)和attr_value_2(属性attr_2的属性值)的非唯一索引键,可以生成多个以101.attr_value_1.attr_value_2为前缀的非唯一索引键。
在另一种可能的实施方式中,宽表中的数据还可以通过如下方式存储:
响应于接收到针对待存储数据的唯一索引键配置指令,确定第二索引标识信息和第二索引属性值;
按照唯一索引键拼接规则,对第二索引标识信息和第二索引属性值进行拼接,得到目标唯一索引键;
在宽表中,将目标唯一索引键与待存储数据的数据标识信息关联存储。
示例地,唯一索引键拼接规则可以为,按照从前到后的顺序依次将第二索引标识信息和第二索引属性值进行拼接。
若需对某个属性的指定属性值配置唯一索引键,可以将第二索引标识信息和该指定属性值按照唯一索引键拼接规则进行拼接。举例来说,若索引标识信息为234,属性attr的abc这一属性值生成唯一索引键,可以生234.abc这一目标唯一索引键,经将234.abc与待存储数据的数据标识信息关联存储于宽表中。这样,在后续的查询过程中,就可以通过attr属性进行反查找。
根据上述数据存储方式的描述,可知本公开的数据查询方式包括但不限于以下三种:实体查询、非唯一索引查询和唯一索引查询。下面将分别通过每一查询方式对本公开的相关步骤进行详细说明。
回到图1,在步骤12中,按照与目标查询方式对应的键拼接规则,对目标查询标识和目标属性信息进行拼接,得到目标键。
在一种可能的实施方式中,若目标查询方式为实体查询,则数据查询指令还可以包括目标数据类型,且目标查询标识为待查询数据的数据标识信息,目标属性信息为待查询数据的属性名称。相应地,步骤12可以包括以下步骤:
对待查询数据的数据标识信息、目标数据类型和待查询数据的属性名称进行拼接,得到目标键。
在另一种可能的实施方式中,若目标查询方式为非唯一索引查询,则目标查询标识为第一目标索引标识信息,且目标属性信息为第一目标索引属性值。相应地,步骤12可以包括以下步骤:
对第一目标索引标识信息和第一目标索引属性值进行拼接,得到目标键。
在另一种可能的实施方式中,若目标查询方式为唯一索引查询,则目标查询标识为第二目标索引标识信息,且目标属性信息为第二目标索引属性值。相应地,步骤11可以包括以下步骤:
对第二目标索引标识信息和第二目标索引属性值进行拼接,得到目标键。
其中,与目标查询方式对应的键拼接规则,实际上与数据存储时存储数据的方式相对应。也就是说,若目标查询方式为实体查询,则与目标查询对应的键拼接规则就是上文中所提到的实体键拼接规则。同理,若目标查询方式为非唯一索引查询,则与目标查询对应的键拼接规则就是上文中所提到的非唯一索引键拼接规则;若目标查询方式为唯一索引查询,则与目标查询对应的键拼接规则就是上文中所提到的唯一索引键拼接规则。
在步骤13中,从用于存储数据的宽表中确定出与目标键对应的目标数据。
在一种可能的实施方式中,若目标查询方式为实体查询,则可以根据目标键,从宽表中定位到与该目标键关联的值,进而确定目标数据。
以文章实体为例,若一文章实体拥有唯一的标识信息123,并对应有标题title、内容content、作者user_id这些属性,在宽表中,底层的存储的键值对可以如下表所示,其中,ent表征数据类型:
123.ent.title title_value
123.ent.content content_value
123.ent.user_id 100
那么,若此时用户需要读取标识信息为123的文章实体的标题和内容属性,根据本公开提供的方法,会拼接出对应两个目标键,分别为123.ent.title和123.ent.content,进而,从上述底层存储中获取对应的属性值,最后打包成文章实体返回给用户。
在另一种可能的实施方式中,若目标查询方式为非唯一索引查询,步骤13可以包括以下步骤:
从宽表中存储的非唯一索引键中,确定前缀与目标键相一致的目标索引键;
从目标索引键中提取数据标识信息,作为目标标识信息;
从宽表中查找与目标标识信息对应的数据,作为目标数据。
如前文所述,若用户配置了非唯一索引,宽表中会存储有多个非唯一索引键,且每一非唯一索引键由索引标识信息、索引属性值和数据标识信息拼接而成。
若用户配置了非唯一索引,第一目标索引标识信息为233,需要根据属性user_id的属性值100反查文章(即查找user_id为100的作者的全部发文),假设user_id为100的作者发表过三篇文章,文章的数据标识信息分别为123、124、125,那么,在宽表中,底层非唯一索引存储的键值对可以如下表所示,其中,预设值为空值null:
233.100.123 null
233.100.124 null
233.100.125 null
从而,通过非唯一索引查询接口,可以扫描宽表中前缀为233.100的所有键,得到所有的目标索引键,分别为233.100.123、233.100.124和233.100.125,进而提取出目标标识信息123、124和125,再根据目标标识信息,从宽表中获取对应的文章实体(实体的查找方式可参见前文)。
在另一种可能的实施方式中,若目标查询方式为唯一索引查询,则可以根据目标键,从宽表中定位到与该目标键关联的数据标识信息,进而确定目标数据。
假设索引标识信息为234,属性attr的abc这一属性值生成唯一索引键,并与数据标识信息150关联存储如下表:
234.abc 150
那么,若根据第二目标索引属性值abc反查文章,根据本公开提供的方法,会拼接出目标键234.abc,并从宽表中读出与234.abc对应的数据标识信息150,再根据数据标识信息150查询对应文章并返回给用户。
图3是根据本公开的一种实施方式提供的数据处理装置的框图。如图3所示,所述装置40包括:
接收模块41,用于接收数据查询指令,所述数据查询指令包括用于查询数据的目标查询方式、目标查询标识和目标属性信息;
第一拼接模块42,用于按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键;
第一确定模块43,用于从用于存储数据的宽表中确定出与所述目标键对应的目标数据,所述宽表基于强一致性的分布式键值存储模型进行数据存储。
可选地,所述宽表中的数据通过如下模块存储:
获取模块,用于获取待存储数据的数据标识信息、数据类型、属性名称和属性值;
第二拼接模块,用于按照用于存储实体的实体键拼接规则,得到目标实体键;
第一存储模块,用于在所述宽表中,将所述目标实体键与所述待存储数据的属性值关联存储。
可选地,所述宽表中的数据还通过如下模块存储:
第二确定模块,用于响应于接收到针对所述待存储数据的非唯一索引键配置指令,确定第一索引标识信息和第一索引属性值;
第三拼接模块,用于按照非唯一索引键拼接规则,对所述第一索引标识信息、所述第一索引属性值和所述待存储数据的数据标识信息进行拼接,得到目标非唯一索引键;
第二存储模块,用于在所述宽表中,将所述目标非唯一索引键与预设值关联存储。
可选地,所述宽表中的数据还通过如下模块存储:
第三确定模块,用于响应于接收到针对所述待存储数据的唯一索引键配置指令,确定第二索引标识信息和第二索引属性值;
第四拼接模块,用于按照唯一索引键拼接规则,对所述第二索引标识信息和所述第二索引属性值进行拼接,得到目标唯一索引键;
第三存储模块,用于在所述宽表中,将所述目标唯一索引键与所述待存储数据的数据标识信息关联存储。
可选地,若所述目标查询方式为实体查询,则所述数据查询指令还包括目标数据类型,且所述目标查询标识为待查询数据的数据标识信息,所述目标属性信息为所述待查询数据的属性名称;
所述第一拼接模块42,包括:
第一拼接子模块,用于对所述待查询数据的数据标识信息、所述目标数据类型和所述待查询数据的属性名称进行拼接,得到所述目标键。
可选地,若所述目标查询方式为非唯一索引查询,则所述目标查询标识为第一目标索引标识信息,且所述目标属性信息为第一目标索引属性值;
所述第一拼接模块42,包括:
第二拼接子模块,用于对所述第一目标索引标识信息和所述第一目标索引属性值进行拼接,得到所述目标键。
可选地,若所述目标查询方式为唯一索引查询,则所述目标查询标识为第二目标索引标识信息,且所述目标属性信息为第二目标索引属性值;
所述第一拼接模块42,包括:
第三拼接子模块,用于对所述第二目标索引标识信息和所述第二目标索引属性值进行拼接,得到所述目标键。
可选地,所述宽表中存储有多个非唯一索引键,且每一非唯一索引键由索引标识信息、索引属性值和数据标识信息拼接而成;
所述第一确定模块43,包括:
确定子模块,用于若所述目标查询方式为非唯一索引查询,从所述宽表中存储的非唯一索引键中,确定前缀与所述目标键相一致的目标索引键;
提取子模块,用于从所述目标索引键中提取数据标识信息,作为目标标识信息;
查找子模块,用于从所述宽表中查找与所述目标标识信息对应的数据,作为所述目标数据。
关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
下面参考图4,其示出了适于用来实现本公开实施例的电子设备600的结构示意图。本公开实施例中的终端设备可以包括但不限于诸如移动电话、笔记本电脑、数字广播接收器、PDA(个人数字助理)、PAD(平板电脑)、PMP(便携式多媒体播放器)、车载终端(例如车载导航终端)等等的移动终端以及诸如数字TV、台式计算机等等的固定终端。图4示出的电子设备仅仅是一个示例,不应对本公开实施例的功能和使用范围带来任何限制。
如图4所示,电子设备600可以包括处理装置(例如中央处理器、图形处理器等)601,其可以根据存储在只读存储器(ROM)602中的程序或者从存储装置608加载到随机访问存储器(RAM)603中的程序而执行各种适当的动作和处理。在RAM 603中,还存储有电子设备600操作所需的各种程序和数据。处理装置601、ROM 602以及RAM 603通过总线604彼此相连。输入/输出(I/O)接口605也连接至总线604。
通常,以下装置可以连接至I/O接口605:包括例如触摸屏、触摸板、键盘、鼠标、摄像头、麦克风、加速度计、陀螺仪等的输入装置606;包括例如液晶显示器(LCD)、扬声器、振动器等的输出装置607;包括例如磁带、硬盘等的存储装置608;以及通信装置609。通信装置609可以允许电子设备600与其他设备进行无线或有线通信以交换数据。虽然图4示出了具有各种装置的电子设备600,但是应理解的是,并不要求实施或具备所有示出的装置。可以替代地实施或具备更多或更少的装置。
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在非暂态计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信装置609从网络上被下载和安装,或者从存储装置608被安装,或者从ROM 602被安装。在该计算机程序被处理装置601执行时,执行本公开实施例的方法中限定的上述功能。
需要说明的是,本公开上述的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本公开中,计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读信号介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:电线、光缆、RF(射频)等等,或者上述的任意合适的组合。
在一些实施方式中,客户端、服务器可以利用诸如HTTP(HyperText TransferProtocol,超文本传输协议)之类的任何当前已知或未来研发的网络协议进行通信,并且可以与任意形式或介质的数字数据通信(例如,通信网络)互连。通信网络的示例包括局域网(“LAN”),广域网(“WAN”),网际网(例如,互联网)以及端对端网络(例如,ad hoc端对端网络),以及任何当前已知或未来研发的网络。
上述计算机可读介质可以是上述电子设备中所包含的;也可以是单独存在,而未装配入该电子设备中。
上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该电子设备执行时,使得该电子设备:接收数据查询指令,所述数据查询指令包括用于查询数据的目标查询方式、目标查询标识和目标属性信息;按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键;从用于存储数据的宽表中确定出与所述目标键对应的目标数据,所述宽表基于强一致性的分布式键值存储模型进行数据存储。
可以以一种或多种程序设计语言或其组合来编写用于执行本公开的操作的计算机程序代码,上述程序设计语言包括但不限于面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言——诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)——连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
附图中的流程图和框图,图示了按照本公开各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本公开实施例中所涉及到的模块可以通过软件的方式实现,也可以通过硬件的方式来实现。其中,模块的名称在某种情况下并不构成对该模块本身的限定,例如,接收模块还可以被描述为“用于接收数据查询指令的模块”。
本文中以上描述的功能可以至少部分地由一个或多个硬件逻辑部件来执行。例如,非限制性地,可以使用的示范类型的硬件逻辑部件包括:现场可编程门阵列(FPGA)、专用集成电路(ASIC)、专用标准产品(ASSP)、片上系统(SOC)、复杂可编程逻辑设备(CPLD)等等。
在本公开的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦除可编程只读存储器(EPROM或快闪存储器)、光纤、便捷式紧凑盘只读存储器(CD-ROM)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
根据本公开的一个或多个实施例,提供了一种数据处理方法,所述方法包括:
接收数据查询指令,所述数据查询指令包括用于查询数据的目标查询方式、目标查询标识和目标属性信息;
按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键;
从用于存储数据的宽表中确定出与所述目标键对应的目标数据,所述宽表基于强一致性的分布式键值存储模型进行数据存储。
根据本公开的一个或多个实施例,提供了一种数据处理方法,所述宽表中的数据通过如下方式存储:
获取待存储数据的数据标识信息、数据类型、属性名称和属性值;
按照用于存储实体的实体键拼接规则,得到目标实体键;
在所述宽表中,将所述目标实体键与所述待存储数据的属性值关联存储。
根据本公开的一个或多个实施例,提供了一种数据处理方法,所述宽表中的数据还通过如下方式存储:
响应于接收到针对所述待存储数据的非唯一索引键配置指令,确定第一索引标识信息和第一索引属性值;
按照非唯一索引键拼接规则,对所述第一索引标识信息、所述第一索引属性值和所述待存储数据的数据标识信息进行拼接,得到目标非唯一索引键;
在所述宽表中,将所述目标非唯一索引键与预设值关联存储。
根据本公开的一个或多个实施例,提供了一种数据处理方法,所述宽表中的数据还通过如下方式存储:
响应于接收到针对所述待存储数据的唯一索引键配置指令,确定第二索引标识信息和第二索引属性值;
按照唯一索引键拼接规则,对所述第二索引标识信息和所述第二索引属性值进行拼接,得到目标唯一索引键;
在所述宽表中,将所述目标唯一索引键与所述待存储数据的数据标识信息关联存储。
根据本公开的一个或多个实施例,提供了一种数据处理方法,若所述目标查询方式为实体查询,则所述数据查询指令还包括目标数据类型,且所述目标查询标识为待查询数据的数据标识信息,所述目标属性信息为所述待查询数据的属性名称;
所述按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键,包括:
对所述待查询数据的数据标识信息、所述目标数据类型和所述待查询数据的属性名称进行拼接,得到所述目标键。
根据本公开的一个或多个实施例,提供了一种数据处理方法,若所述目标查询方式为非唯一索引查询,则所述目标查询标识为第一目标索引标识信息,且所述目标属性信息为第一目标索引属性值;
所述按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键,包括:
对所述第一目标索引标识信息和所述第一目标索引属性值进行拼接,得到所述目标键。
根据本公开的一个或多个实施例,提供了一种数据处理方法,若所述目标查询方式为唯一索引查询,则所述目标查询标识为第二目标索引标识信息,且所述目标属性信息为第二目标索引属性值;
所述按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键,包括:
对所述第二目标索引标识信息和所述第二目标索引属性值进行拼接,得到所述目标键。
根据本公开的一个或多个实施例,提供了一种数据处理方法,所述宽表中存储有多个非唯一索引键,且每一非唯一索引键由索引标识信息、索引属性值和数据标识信息拼接而成;
若所述目标查询方式为非唯一索引查询,所述从用于存储数据的宽表中确定出与所述目标键对应的目标数据,包括:
从所述宽表中存储的非唯一索引键中,确定前缀与所述目标键相一致的目标索引键;
从所述目标索引键中提取数据标识信息,作为目标标识信息;
从所述宽表中查找与所述目标标识信息对应的数据,作为所述目标数据。
根据本公开的一个或多个实施例,提供了一种数据处理装置,所述装置包括:
接收模块,用于接收数据查询指令,所述数据查询指令包括用于查询数据的目标查询方式、目标查询标识和目标属性信息;
第一拼接模块,用于按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键;
第一确定模块,用于从用于存储数据的宽表中确定出与所述目标键对应的目标数据,所述宽表基于强一致性的分布式键值存储模型进行数据存储。
根据本公开的一个或多个实施例,提供了一种计算机可读介质,其上存储有计算机程序,该程序被处理装置执行时实现本公开任意实施例所述的图像处理方法的步骤。
根据本公开的一个或多个实施例,提供了一种电子设备,包括:
存储装置,其上存储有计算机程序;
处理装置,用于执行所述存储装置中的所述计算机程序,以实现本公开任意实施例所述的图像处理方法的步骤。
以上描述仅为本公开的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本公开中所涉及的公开范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述公开构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本公开中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。
此外,虽然采用特定次序描绘了各操作,但是这不应当理解为要求这些操作以所示出的特定次序或以顺序次序执行来执行。在一定环境下,多任务和并行处理可能是有利的。同样地,虽然在上面论述中包含了若干具体实现细节,但是这些不应当被解释为对本公开的范围的限制。在单独的实施例的上下文中描述的某些特征还可以组合地实现在单个实施例中。相反地,在单个实施例的上下文中描述的各种特征也可以单独地或以任何合适的子组合的方式实现在多个实施例中。
尽管已经采用特定于结构特征和/或方法逻辑动作的语言描述了本主题,但是应当理解所附权利要求书中所限定的主题未必局限于上面描述的特定特征或动作。相反,上面所描述的特定特征和动作仅仅是实现权利要求书的示例形式。关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。

Claims (11)

1.一种数据处理方法,其特征在于,所述方法包括:
接收数据查询指令,所述数据查询指令包括用于查询数据的目标查询方式、目标查询标识和目标属性信息;
按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键;
从用于存储数据的宽表中确定出与所述目标键对应的目标数据,所述宽表基于强一致性的分布式键值存储模型进行数据存储。
2.根据权利要求1所述的方法,其特征在于,所述宽表中的数据通过如下方式存储:
获取待存储数据的数据标识信息、数据类型、属性名称和属性值;
按照用于存储实体的实体键拼接规则,得到目标实体键;
在所述宽表中,将所述目标实体键与所述待存储数据的属性值关联存储。
3.根据权利要求2所述的方法,其特征在于,所述宽表中的数据还通过如下方式存储:
响应于接收到针对所述待存储数据的非唯一索引键配置指令,确定第一索引标识信息和第一索引属性值;
按照非唯一索引键拼接规则,对所述第一索引标识信息、所述第一索引属性值和所述待存储数据的数据标识信息进行拼接,得到目标非唯一索引键;
在所述宽表中,将所述目标非唯一索引键与预设值关联存储。
4.根据权利要求2所述的方法,其特征在于,所述宽表中的数据还通过如下方式存储:
响应于接收到针对所述待存储数据的唯一索引键配置指令,确定第二索引标识信息和第二索引属性值;
按照唯一索引键拼接规则,对所述第二索引标识信息和所述第二索引属性值进行拼接,得到目标唯一索引键;
在所述宽表中,将所述目标唯一索引键与所述待存储数据的数据标识信息关联存储。
5.根据权利要求1所述的方法,其特征在于,若所述目标查询方式为实体查询,则所述数据查询指令还包括目标数据类型,且所述目标查询标识为待查询数据的数据标识信息,所述目标属性信息为所述待查询数据的属性名称;
所述按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键,包括:
对所述待查询数据的数据标识信息、所述目标数据类型和所述待查询数据的属性名称进行拼接,得到所述目标键。
6.根据权利要求1所述的方法,其特征在于,若所述目标查询方式为非唯一索引查询,则所述目标查询标识为第一目标索引标识信息,且所述目标属性信息为第一目标索引属性值;
所述按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键,包括:
对所述第一目标索引标识信息和所述第一目标索引属性值进行拼接,得到所述目标键。
7.根据权利要求1所述的方法,其特征在于,若所述目标查询方式为唯一索引查询,则所述目标查询标识为第二目标索引标识信息,且所述目标属性信息为第二目标索引属性值;
所述按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键,包括:
对所述第二目标索引标识信息和所述第二目标索引属性值进行拼接,得到所述目标键。
8.根据权利要求1所述的方法,其特征在于,所述宽表中存储有多个非唯一索引键,且每一非唯一索引键由索引标识信息、索引属性值和数据标识信息拼接而成;
若所述目标查询方式为非唯一索引查询,所述从用于存储数据的宽表中确定出与所述目标键对应的目标数据,包括:
从所述宽表中存储的非唯一索引键中,确定前缀与所述目标键相一致的目标索引键;
从所述目标索引键中提取数据标识信息,作为目标标识信息;
从所述宽表中查找与所述目标标识信息对应的数据,作为所述目标数据。
9.一种数据处理装置,其特征在于,所述装置包括:
接收模块,用于接收数据查询指令,所述数据查询指令包括用于查询数据的目标查询方式、目标查询标识和目标属性信息;
第一拼接模块,用于按照与所述目标查询方式对应的键拼接规则,对所述目标查询标识和所述目标属性信息进行拼接,得到目标键;
第一确定模块,用于从用于存储数据的宽表中确定出与所述目标键对应的目标数据,所述宽表基于强一致性的分布式键值存储模型进行数据存储。
10.一种计算机可读介质,其上存储有计算机程序,其特征在于,该程序被处理装置执行时实现权利要求1-8中任一项所述方法的步骤。
11.一种电子设备,其特征在于,包括:
存储装置,其上存储有计算机程序;
处理装置,用于执行所述存储装置中的所述计算机程序,以实现权利要求1-8中任一项所述方法的步骤。
CN202210880610.XA 2022-07-25 2022-07-25 数据处理方法、装置、可读介质及电子设备 Pending CN115168362A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202210880610.XA CN115168362A (zh) 2022-07-25 2022-07-25 数据处理方法、装置、可读介质及电子设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202210880610.XA CN115168362A (zh) 2022-07-25 2022-07-25 数据处理方法、装置、可读介质及电子设备

Publications (1)

Publication Number Publication Date
CN115168362A true CN115168362A (zh) 2022-10-11

Family

ID=83496292

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202210880610.XA Pending CN115168362A (zh) 2022-07-25 2022-07-25 数据处理方法、装置、可读介质及电子设备

Country Status (1)

Country Link
CN (1) CN115168362A (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN116070601A (zh) * 2023-03-28 2023-05-05 联仁健康医疗大数据科技股份有限公司 数据拼接方法、装置、电子设备及存储介质
CN116662622A (zh) * 2023-07-25 2023-08-29 北京国科恒通科技股份有限公司 电网数据一致性比对方法及装置、介质及电子设备

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN116070601A (zh) * 2023-03-28 2023-05-05 联仁健康医疗大数据科技股份有限公司 数据拼接方法、装置、电子设备及存储介质
CN116662622A (zh) * 2023-07-25 2023-08-29 北京国科恒通科技股份有限公司 电网数据一致性比对方法及装置、介质及电子设备
CN116662622B (zh) * 2023-07-25 2023-10-31 北京国科恒通科技股份有限公司 电网数据一致性比对方法及装置、介质及电子设备

Similar Documents

Publication Publication Date Title
CN107704202B (zh) 一种数据快速读写的方法和装置
CN115168362A (zh) 数据处理方法、装置、可读介质及电子设备
CN108897874B (zh) 用于处理数据的方法和装置
CN109508361B (zh) 用于输出信息的方法和装置
CN111400625B (zh) 页面处理方法、装置、电子设备及计算机可读存储介质
CN111061680A (zh) 一种数据检索的方法和装置
CN111800513A (zh) 用于推送信息的方法、装置、电子设备计算机可读介质
CN113704291A (zh) 数据查询方法、装置、存储介质及电子设备
CN113918659A (zh) 数据操作方法、装置、存储介质及电子设备
CN110852720A (zh) 文档的处理方法、装置、设备及存储介质
CN110110184B (zh) 信息查询方法、系统、计算机系统及存储介质
CN112162987A (zh) 数据处理方法、装置、设备及存储介质
CN110888839A (zh) 数据存储及数据搜索方法和装置
CN112307061A (zh) 用于查询数据的方法和装置
CN117009430A (zh) 数据管理方法、装置和存储介质及电子设备
CN111597439A (zh) 信息处理方法、装置和电子设备
CN113760929A (zh) 数据同步方法、装置、电子设备和计算机可读介质
CN112699289A (zh) 房源信息聚合展示方法、装置、电子设备和计算机可读介质
CN111782895A (zh) 检索处理方法、装置、可读介质及电子设备
CN117692672B (zh) 基于快照的视频信息发送方法、装置、电子设备和介质
CN116305288B (zh) 一种隔离数据库资源的方法、装置、设备和存储介质
CN115994151B (zh) 数据请求变更方法、装置、电子设备和计算机可读介质
CN110889040B (zh) 用于推送信息的方法和装置
CN110619093B (zh) 确定搜索项目的顺序的方法、装置、电子设备和计算机可读存储介质
CN113268488B (zh) 数据持久化的方法和装置

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination