CN111966870A - 一种基于图数据库的社区关系实时构建方法及其相关组件 - Google Patents

一种基于图数据库的社区关系实时构建方法及其相关组件 Download PDF

Info

Publication number
CN111966870A
CN111966870A CN202010819596.3A CN202010819596A CN111966870A CN 111966870 A CN111966870 A CN 111966870A CN 202010819596 A CN202010819596 A CN 202010819596A CN 111966870 A CN111966870 A CN 111966870A
Authority
CN
China
Prior art keywords
relationship
data
entities
relation
graph database
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
CN202010819596.3A
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.)
Shenzhen Wanwuyun Technology Co ltd
Original Assignee
Shenzhen Wanwuyun Technology 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 Shenzhen Wanwuyun Technology Co ltd filed Critical Shenzhen Wanwuyun Technology Co ltd
Priority to CN202010819596.3A priority Critical patent/CN111966870A/zh
Publication of CN111966870A publication Critical patent/CN111966870A/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/90Details of database functions independent of the retrieved data types
    • G06F16/903Querying
    • G06F16/90335Query processing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/901Indexing; Data structures therefor; Storage structures
    • G06F16/9024Graphs; Linked lists

Landscapes

  • Engineering & Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Data Mining & Analysis (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

一种基于图数据库的社区关系实时构建方法及其相关组件
技术领域
本发明涉及图数据处理技术领域,特别涉及一种基于图数据库的社区关系实时构建方法、装置、计算机设备及存储介质。
背景技术
新时代背景下,社会各界对社区的规划、发展、维护提出了新的要求,以智慧社区建设为统领,提高新型城镇化质量是构建现代社区的共识。物业社区信息化管理系统是基于社区场景对业主、访客、车辆、不动产等多种实体构建的管理平台,为推动社区公共服务水平和规划建设提供了数字化支撑。
随着城镇化建设的步伐加快,信息系统中维护的人-物信息维度和总量快速增加,人-物实体之间的互动频率加快。传统社区信息化管理系统的数据存储方式是基于关系模型的存储方式,适用于存储结构化数据,通过SQL查询语言提供便捷的数据查询方式,主要应用于事务的操作性处理,但难以满足大数据时代背景下大型社区的数字化运营涉及的快速访问和分析的需求,所受限制较大,主要包括:1、存储容量受限,关系数据库可以有效处理TB级的数据(TB是一个计算机存储容量的单位,它等于2的40次方字节,或者接近一万亿字节),而对PB级的数据量(PB是一个计算机存储容量的单位,它等于2的50次方字节,或者接近1000TB),目前较难处理;2、关系模型按内容访问的特点束缚了对海量数据的快速访问能力;3、可扩展性差,针对特定应用的设计特性使其难以应对海量复杂数据;4、无法对关系时效性进行有效判定。
发明内容
本发明的目的是提供一种基于图数据库的社区关系实时构建方法、装置、计算机设备及存储介质,旨在解决现有的社区数据存储方式存储容量受限、访问速度慢、扩展性差以及实体之间关系不具有时效性的问题。
本发明实施例提供一种基于图数据库的社区关系实时构建方法,其包括:
采集社区的实体数据以及实体之间关系数据,通过数据管道将所述实体数据以及实体之间关系数据导入图数据库中,并根据所述实体数据创建图数据库的节点;
根据所述实体之间关系数据对节点之间的关系进行创建,并为所述关系赋予动态属性;所述关系包括同类关系和异类关系;所述动态属性包括:关系生效时间和关系结束时间;
当实体之间关系数据发生变化时,根据新的实体之间关系数据对节点之间的关系进行更新,并为所述关系赋予新的动态属性;
当实体之间关系数据失效时,根据当前实体之间关系数据对节点之间的关系进行删除,并更新失效关系的动态属性;
当接收到查询请求时,获取待查询的目标实体数据,根据所述目标实体数据在所述图数据库中进行查询,获取目标实体的历史关系状态和实时关系状态。
优选的,所述采集社区的实体数据以及实体之间关系数据,通过数据管道将所述实体数据以及实体之间关系数据导入图数据库中,并根据所述实体数据创建图数据库的节点,包括:
采集社区的实体数据以及实体之间关系数据,并存储至关系型数据库;
构建数据管道,将关系型数据库中存储的实体数据以及实体之间关系数据导入所述图数据库;
根据所述实体数据创建图数据库的节点,并基于预先定义的配置信息为所述节点赋予相应的类型和属性。
优选的,所述根据所述实体之间关系数据对节点之间的关系进行创建,并为所述关系赋予动态属性,包括:
根据所述实体之间关系数据,从候选池中选出待操作的批量的节点对,创建所述节点对的关系;
根据所述实体之间关系数据,为所述节点对的关系赋予动态属性。
优选的,所述当实体之间关系数据发生变化时,根据新的实体之间关系数据对节点之间的关系进行更新,并为所述关系赋予新的动态属性,包括:
当实体之间关系数据发生变化时,从候选池中选出待操作的节点对;
判断所述节点对在所述图数据库中是否存在关系;
若存在关系,则根据新的实体之间关系数据对所述节点对的关系进行更新,并为所述关系赋予新的动态属性;
若不存在关系,则创建所述节点对的关系,并为所述节点对的关系赋予动态属性。
优选的,所述根据新的实体之间关系数据对节点之间的关系进行更新,并为所述关系赋予新的动态属性,包括:
将所述节点对的上一条关系的关系结束时间设置为当前时间;
为所述节点对创建新的关系,并根据新的实体之间关系数据将新的关系的节点生效时间设置为当前时间,并对新的关系的其他动态属性进行设置。
优选的,所述当实体之间关系数据失效时,根据当前实体之间关系数据对节点之间的关系进行删除,并更新失效关系的动态属性,包括:
当实体之间关系数据失效时,从候选池中选出待操作的节点对;
根据当前实体之间关系数据对节点之间的关系进行删除,并更新失效关系的动态属性。
优选的,所述当接收到查询请求时,获取待查询的目标实体数据,根据所述目标实体数据在所述图数据库中进行查询,获取目标实体的历史关系状态和实时关系状态,包括:
当接收到查询请求时,获取待查询的目标实体数据;
根据所述目标实体数据在所述图数据库中查询与目标实体有关系的关联实体;
在所述图数据库中查询所述目标实体与关联实体之间的关系;
若所述关系中包含多条关系,则将当前关系作为实时关系状态返回,并将当前关系之前的所有关系作为历史关系状态返回。
本发明实施例提供一种基于图数据库的社区关系实时构建装置,其包括:
实体数据采集单元,用于采集社区的实体数据以及实体之间关系数据,通过数据管道将所述实体数据以及实体之间关系数据导入图数据库中,并根据所述实体数据创建图数据库的节点;
节点关系创建单元,用于根据所述实体之间关系数据对节点之间的关系进行创建,并为所述关系赋予动态属性;所述关系包括同类关系和异类关系;所述动态属性包括:关系生效时间和关系结束时间;
节点关系更新单元,用于当实体之间关系数据发生变化时,根据新的实体之间关系数据对节点之间的关系进行更新,并为所述关系赋予新的动态属性;
节点关系删除单元,用于当实体之间关系数据失效时,根据当前实体之间关系数据对节点之间的关系进行删除,并更新失效关系的动态属性;
实体数据查询单元,用于当接收到查询请求时,获取待查询的目标实体数据,根据所述目标实体数据在所述图数据库中进行查询,获取目标实体的历史关系状态和实时关系状态。
本发明实施例提供一种计算机设备,包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如上所述的基于图数据库的社区关系实时构建方法。
本发明实施例提供一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如上所述的基于图数据库的社区关系实时构建方法。
本发明实施例提供了一种基于图数据库的社区关系实时构建方法、装置、计算机设备及存储介质,其中,方法包括:采集社区的实体数据以及实体之间关系数据,通过数据管道将所述实体数据以及实体之间关系数据导入图数据库中,并根据所述实体数据创建图数据库的节点;根据所述实体之间关系数据对节点之间的关系进行创建,并为所述关系赋予动态属性;所述关系包括同类关系和异类关系;所述动态属性包括:关系生效时间和关系结束时间;当实体之间关系数据发生变化时,根据新的实体之间关系数据对节点之间的关系进行更新,并为所述关系赋予新的动态属性;当实体之间关系数据失效时,根据当前实体之间关系数据对节点之间的关系进行删除,并更新失效关系的动态属性;当接收到查询请求时,获取待查询的目标实体数据,根据所述目标实体数据在所述图数据库中进行查询,获取目标实体的历史关系状态和实时关系状态。本发明实施例通过将实体数据以及实体之间关系数据存储至图数据库中,实现海量数据的存储,且可实现快速访问,面对海量复杂的数据可扩展性强,实体数据及实体之间关系数据的时效性高。
附图说明
为了更清楚地说明本发明实施例技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例所提供的一种基于图数据库的社区关系实时构建方法的流程示意图;
图2为本发明实施例所提供的一种基于图数据库的社区关系实时构建方法的创建关系拓扑图;
图3为本发明实施例所提供的一种基于图数据库的社区关系实时构建方法的更新关系拓扑图;
图4为本发明实施例所提供的一种基于图数据库的社区关系实时构建方法的删除关系拓扑图;
图5为本发明实施例所提供的一种基于图数据库的社区关系实时构建方法的创建新关系拓扑图;
图6为本发明实施例所提供的一种基于图数据库的社区关系实时构建装置的示意性框图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
应当理解,在此本发明说明书中所使用的术语仅仅是出于描述特定实施例的目的而并不意在限制本发明。如在本发明说明书和所附权利要求书中所使用的那样,除非上下文清楚地指明其它情况,否则单数形式的“一”、“一个”及“该”意在包括复数形式。
还应当进一步理解,在本发明说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
请参阅图1,图1为本发明实施例提供的一种基于图数据库的社区关系实时构建方法的流程示意图,该方法可以包括步骤S101~S105:
S101、采集社区的实体数据以及实体之间关系数据,通过数据管道将所述实体数据以及实体之间关系数据导入图数据库中,并根据所述实体数据创建图数据库的节点;
在本步骤中,采集社区中实体的实体数据,根据所述实体数据创建图数据库的节点。后续步骤中可将节点与节点之间进行连接形成节点之间的边,从而完成图数据库的构建。
所述实体数据作为图数据库中的节点导入图数据库,每一个节点表示一个不同的实体。所述图数据库是一种NoSQL数据库,它应用图形理论描述实体之间的关系信息,数据以节点和边的形式存储,每个节点表示一个实体,每条边为实体与实体之间的“关系”,由此构建关系网络图。
在一实施例中,所述步骤S101包括:
采集社区的实体数据以及实体之间关系数据,并存储至关系型数据库;
构建数据管道,将关系型数据库中存储的实体数据以及实体之间关系数据导入所述图数据库;
根据所述实体数据创建图数据库的节点,并基于预先定义的配置信息为所述节点赋予相应的类型和属性。
在本实施例中,在采集所述实体数据和实体之间关系数据完毕后,通常将这些数据存储至关系型数据库中,以方便随时调用;在构建图数据库时,需要将实体数据导入作为节点,通过构建好的数据管道将这些数据输送到图数据库中。由于所采集的实体数据存在多样性,因此需要预先进行定义,给这些节点赋予相应的类型(可称为节点类型)及属性(可称为节点属性)。
具体的,可通过建立数据模型,定义图数据库中顶点(即节点)类型及属性,使得图数据库中人、动产、不动产、组织等实体数据的存储、查询可以按照用户预定义的模型配置信息运行,极大地简化了图数据库的创建与应用,从而提高了图数据库应用的易用性和通用性。模型配置信息以yaml格式存储(yaml是一种直观的能够被电脑识别的数据序列化格式,是一个可读性高并且容易被人类阅读,容易和脚本语言交互,用来表达资料序列的编程语言)。基于配置文件,可构建数据管道,将数据由关系型数据库导入图数据库,创建图数据库中的节点。
S102、根据所述实体之间关系数据对节点之间的关系进行创建,并为所述关系赋予动态属性;所述关系包括同类关系和异类关系;所述动态属性包括:关系生效时间和关系结束时间;
前述步骤中,依据所述实体数据创建所述节点,本步骤中,依据所述实体之间关系数据创建所述节点之间的关系。本实施例中,节点间的关系存在时效性,例如节点之间关系为租赁关系,则这种关系具有生效期限,因此在对节点之间的关系进行关联之后需要对所述关系赋予动态属性,所述动态属性包括:通用唯一识别码(即ID编码)、关系生效时间、关系结束时间以及关系类型,所述关系类型可分为同类关系和异类关系。
当然,两个节点之间可以只存在一种关系,两个节点之间也可以同时存在多种关系,例如一个节点A和另一个节点B之间存在租赁关系,同时还存在亲戚关系。这些关系可以是有向的,也可以是无向的。在构建图数据库时,需要根据节点之间的所有关系进行关联,以获得更加全面的数据。
本步骤中主要围绕着人、动产、不动产、组织等实体构建相应的关联组件(用于进行关系关联的组件),根据关系类型分为同类关系和异类关系。其中,同类关系关联组件包括:人际关系组件、组织关系组件、不动产关系组件、动产关系组件。异类关系关联组件包括:人-动产关系组件、人-不动产关系组件、人-组织关系组件、组织-动产关系组件、组织-不动产关系组件、动产-不动产关系组件。
具体的,人际关系组件可操作范围包括:父子(女)、母子(女)、夫妻、兄(姐)妹(弟)等法律认可的亲属关系;访客-住户等短期非商业关系;家政服务人员(保姆、保洁、维修安装)、中介-雇主等短期商业活动关系;承租人-出租人等中长期商业活动关系。
具体的,人-不动产关系关联组件可操作范围包括:人-房之间的拥有、居住、租赁、短期拜访、服务等关系;人-车位之间的购买、租赁、短期使用等关系。
具体的,人-动产关系关联组件可操作范围包括:临时使用权、拥有产权等关系。
在一具体实施例中,所述根据所述实体之间关系数据对节点之间的关系进行创建,并为所述关系赋予动态属性,包括:
根据所述实体之间关系数据,从候选池中选出待操作的批量的节点对,创建所述节点对的关系;
根据所述实体之间关系数据,为所述节点对的关系赋予动态属性。
在本实施例中,所述候选池中存储有图数据库中的所有节点,首先根据实体之间关系数据从所述候选池中挑选出有关系的节点对,本步骤可以进行批量挑选,挑选的方式可以是根据时间段进行批量挑选,也可以是根据关系类型进行批量挑选。然后为挑选出的节点对创建节点对的关系。当节点对从候选池中挑选出来后,应对候选池中的节点对进行标记,表示该节点对已被挑选,下一次无需继续重复挑选。然后根据所述实体之间关系数据为节点对的关系赋予动态属性。
S103、当实体之间关系数据发生变化时,根据新的实体之间关系数据对节点之间的关系进行更新,并为所述关系赋予新的动态属性;
在本步骤中,所述实体之间关系数据不是固定不变的,因此需要及时对实体之间关系数据进行更新,以此对图数据库中的节点之间的关系进行更新,并赋予新的动态属性。
例如两个节点分别代表房东和租客,则所述节点对的关系为租赁关系,那么所述节点对关系的动态属性包括租赁生效时间和租赁结束时间。若租客的租赁时限已经达到租赁结束时间,则这种关系将会解除,租客与房东这两个节点之间不存在别的关系,那么这一节点对之间也不存在关系。此时需要对两个节点之间的关系进行更新,并赋予节点之间的关系新的动态属性。
在一实施例中,所述步骤S103包括:
当实体之间关系数据发生变化时,从候选池中选出待操作的节点对;
判断所述节点对在所述图数据库中是否存在关系;
若存在关系,则根据新的实体之间关系数据对所述节点对的关系进行更新,并为所述关系赋予新的动态属性;
若不存在关系,则创建所述节点对的关系,并为所述节点对的关系赋予动态属性。
在本实施例中,所述节点对的关系随着所述实体之间关系数据变化而变化,在所述实体之间关系数据发生变化时,将对应的节点对放入到候选池中,以便后续对其关系进行更新;在候选池中选择待操作的节点对,并判断节点对之间是否存在关系,若存在关系,则对节点对的关系进行更新,并赋予新的动态属性,若不存在关系,则为所述节点对创建一个关系,并赋予动态属性。
具体的,从候选池中选出进行待操作的节点对。若所选节点对之间原先没有关联关系,即需要创建关系,则在图数据库中创建节点之间的关系。其中,创建关系操作中关系结束时间的默认值为None。若所选节点对之间原先存在联系,则需要对关系进行更新,赋予新的动态属性。
在一具体实施例中,所述根据新的实体之间关系数据对节点之间的关系进行更新,并为所述关系赋予新的动态属性包括:
将所述节点对的上一条关系的关系结束时间设置为当前时间;
为所述节点对创建新的关系,并根据新的实体之间关系数据将新的关系的节点生效时间设置为当前时间,并对新的关系的其他动态属性进行设置。
在本实施例中,所述节点对之间存在新的关系,则对节点对的关系进行更新,节点对新的关系的关系生效时间即为节点对上一条关系的关系结束时间。
例如:房东A将房屋C租赁给租客B居住,此时节点对分别为房东A与租客B,所述节点对的关系为租赁关系,在租客B租赁过程中,对居住的房屋C感到十分满意,因此在租赁合同到期后续约,此时房东A与租客B之间的上一个租赁关系结束,这个关系结束时间即为租赁合同到期时间。房东A与租客B之间新的关系依据新的租赁合同进行创建。
具体的,将上一条关系Ek(n-1)的关系结束时间设置为tn,创建新的关系Ekn,设定新的关系Ekn的关系生效时间为tn,新的关系的关系结束时间为默认值None。特别的,本实施例中,两个节点之间的所有关系以有序队列的形式存储。
当然,由于每一条关系都具有动态属性,在上一条关系结束时,新的关系可能还没有创建,此时上一条关系的关系结束时间就无法等同于新关系的关系生效时间。具体的,将上一条关系Ek(n-1)的关系结束时间设置为tn,在一段时间后创建新的关系Ekn,此时新的关系Ekn的关系生效时间不为tn。举例来说:在上一条关系中,所述节点对的两个节点分别表示房东A与租客B,此时节点对所代表的关系为租赁关系,当租客B的租赁合约到期后,租客B因没有找到新的房屋搬离,在租赁合约到期一天后,租客B重新与房东A签订新的租赁合约,此时房东A与租客B之间的新关系的关系生效时间与房东A与租客B上一条关系的关系结束时间不为同一时间。
相应的,在上一条关系结束之前,新的关系可能已经提前建立,此时上一条关系的关系结束时间也无法等同于新关系的关系生效时间。具体的,将上一条关系Ek(n-1)的关系结束时间设置为tn,在关系Ek(n-1)的关系结束时间之前创建新的关系Ekn,此时新的关系Ekn的关系生效时间不为tn。举例来说:在上一条关系中,所述节点对的两个节点分别表示房东A与租客B,此时节点对所代表的关系为租赁关系,租客B在发现租赁合约即将到期后,与房东A进行协商,在合约到期之前与房东A重新签订了租赁合约,此时房东A与租客B之间的新关系的关系生效时间与房东A与租客B上一条关系的关系结束时间不为同一时间。
通过对节点对之间关系的更新,使所述图数据库更具有时效性,更好的反应了实体之间的关系变化。
S104、当实体之间关系数据失效时,根据当前实体之间关系数据对节点之间的关系进行删除,并更新失效关系的动态属性;
在本步骤中,所述节点对的关系随着所述实体之间关系数据的失效而发生变化,将对应的节点对之间的关系进行删除,并将当前时间作为所述节点对的关系结束时间。
也就是说,本步骤中关系的删除操作并不是直接将图数据库中的关系进行删除,而是通过更新关系Ekn的有效时间来实现,以保证本实施例中关系的时效特性。
在一实施例中,所述步骤S104包括:
当实体之间关系数据失效时,从候选池中选出待操作的节点对;
根据当前实体之间关系数据对节点之间的关系进行删除,并更新失效关系的动态属性。
在本实施例中,在候选池中找出关系失效的节点对,并将该节点对的关系结束时间设为当前时间。
例如,所述节点对对应的实体分别表示房东和租客,在上一条关系中,租客租赁了房东的A号房,房东与租客之间的关系为租赁关系,由于租赁时间到期,租赁关系结束,租客在租赁到期之前提前找到了更加满意的B号房,没有跟房东续签租赁合约,此时房东与租客之间没有产生新的关系,因此,将上一条关系中的关系结束时间设置为当前时间。这种关系生效时间和关系结束时间均由具体时间表示的,即代表着这条关系已经失效。
S105、当接收到查询请求时,获取待查询的目标实体数据,根据所述目标实体数据在所述图数据库中进行查询,获取目标实体的历史关系状态和实时关系状态。
在本步骤中,当需要进行查询时,根据需要查询的目标实体数据,在所述图数据库中进行查询,这种查询方式更加高效。查询范围可以是目标实体的实时关系状态或特定时间段的历史关系状态。所述历史关系状态和实时关系状态是通过关系的起止时间戳(时间戳是最基本的时间序列数据,用于把数值与时点关联在一起)进行判定的,因此查询功能更加定制化。
本步骤中,所述目标实体数据可以是一个目标实体的数据,也可以是两个目标实体的数据,或者多个目标实体的数据。当目标实体数据是一个目标实体的数据时,则在所述图数据库中查询目标实体的所有历史关系状态和所有实时关系状态,即其他实体与目标实体之间的所有关系。
当所述目标实体数据是两个目标实体的数据或者多个目标实体的数据时,则在所述图数据库中查询这两个目标实体之间的所有历史关系状态和所有实时关系状态,或者多个目标实体两两之间的所有历史关系状态和所有实时关系状态。
本步骤基于图论及分析算法进行查询,所述分析算法包括广度优先搜索算法、深度优先搜索算法、K步连通子图、拓扑排序算法、关键路径算法、最短路径算法中的至少其一。
在一实施例中,所述步骤S105包括:
当接收到查询请求时,获取待查询的目标实体数据;
根据所述目标实体数据在所述图数据库中查询与目标实体有关系的关联实体;
在所述图数据库中查询所述目标实体与关联实体之间的关系;
若所述关系中包含多条关系,则将当前关系作为实时关系状态返回,并将当前关系之前的所有关系作为历史关系状态返回。
在本实施例中,在进行查询时,当所述目标实体在图数据库中存在与之有关系的关联实体时,即可在所述图数据库中找出目标实体与关联实体之间的关系,并将当前关系作为实时关系状态返回,若目标实体与关联实体之间存在历史关系,则将当前关系之前的所有关系作为历史关系状态返回。
具体的,依据查询请求的要求,实时关系状态可以通过筛选出与所述目标实体的关系结束时间为None的实体之间关系数据进行获取。历史关系状态的查询通过查询时间戳与实体之间关系数据的终止时间进行对比,选择符合筛选条件的特定时间段的实体之间关系数据。
所述目标实体在图数据库中的关联实体可能有1个,例如:A和B都是在同一房屋C中的租客,A和B之间的关系为室友关系,A在居住一段时间后因觉得房屋C符合自己购房要求,并将房屋C购买,A仍然和B一起居住在房屋C中,此时A和B之间的关系就转变为了租赁关系,此时租赁关系作为A和B之间的当前关系,室友关系作为A和B的历史关系。
所述目标实体在图数据库中的关联实体可能有多个,则查询所有与所述目标实体具有关系的关联实体,并将这些关联实体与目标实体之间的当前关系一一返回。例如:目标实体为房屋A,与之有关系的关联实体有房东B、租客C,此时房东B与房屋A之间为拥有关系,租客C与房屋A为居住关系,租客C在一段时间后搬离,租客D在租客C搬离后入住了房屋A,租客D与房屋A为居住关系。此时返回的结果为房东B与房屋A之间为拥有关系、租客D与房屋A为居住关系,这些都是房屋A的当前关系,租客C与房屋A为居住关系则为房屋A的历史关系。
具体的,如图2所示,业主张三拥有两套房屋:3单元1101和3单元1201。张三与妻子李四和儿子小张一同居住在3单元1101。由于3单元1201闲置,业主张三将闲置房屋3单元1201租赁给王五,双方在2019年2月1日签订了租赁合同。在租赁合同生效后,通过本发明所述方法进行实时关系创建。查询涉及本业务的节点对(张三和王五)及相关的人物关系拓扑,创建节点对(张三和王五)的人物关系,并定义关系类型、关系生效时间和关系结束时间等属性。具体的,设定人物关系为单向关系:租赁关系;关系生效时间为2019年2月1日;关系结束时间为None。
在租赁合同生效当日,王五即入住3单元1201,王五与房屋即建立单向关系:居住关系。该关系的关系生效时间即设定为2019年2月1日,关系结束时间为None。
如图3所示,在租赁合同生效期间,王五从2019年10月1日起不在所租赁的房屋内居住。依据此事务,更新最近的人房关系的动态属性。王五从2019年11月11日后再次返回租赁的房屋内居住。依据此事务,再创建新的人房关系。该关系的关系生效时间为2019年11月11日,关系结束时间为None。
如图4所示,在当前租赁合同结束后(结束时间为2020年2月1日),业主张三与租客王五没有续签租赁合同。依据此事务,删除业主张三与王五的租赁关系。具体的,将张三与王五的租赁关系结束时间设定为2020年2月1日。
如图5所示,业主张三与新的租户赵六于2020年2月1日签订了租赁合约。针对此业务,创建新的节点对关系。新的节点对关系的关系生效时间为2020年2月1日,关系结束时间为None。
请参阅图6,图6为本发明实施例提供的一种基于图数据库的社区关系实时构建装置的示意性框图。该基于图数据库的社区关系实时构建装置200包括:
实体数据采集单元201,用于采集社区的实体数据以及实体之间关系数据,通过数据管道将所述实体数据以及实体之间关系数据导入图数据库中,并根据所述实体数据创建图数据库的节点;
节点关系创建单元202,用于根据所述实体之间关系数据对节点之间的关系进行创建,并为所述关系赋予动态属性;所述关系包括同类关系和异类关系;所述动态属性包括:关系生效时间和关系结束时间;
节点关系更新单元203,用于当实体之间关系数据发生变化时,根据新的实体之间关系数据对节点之间的关系进行更新,并为所述关系赋予新的动态属性;
节点关系删除单元204,用于当实体之间关系数据失效时,根据当前实体之间关系数据对节点之间的关系进行删除,并更新失效关系的动态属性;
实体数据查询单元205,用于当接收到查询请求时,获取待查询的目标实体数据,根据所述目标实体数据在所述图数据库中进行查询,获取目标实体的历史关系状态和实时关系状态。
在一实施例中,所述实体数据采集单元201包括:
采集存储单元,用于采集社区的实体数据以及实体之间关系数据,并存储至关系型数据库;
数据管道构建单元,用于构建数据管道,将关系型数据库中存储的实体数据以及实体之间关系数据导入所述图数据库;
节点创建单元,用于根据所述实体数据创建图数据库的节点,并基于预先定义的配置信息为所述节点赋予相应的类型和属性。
在一实施例中,所述节点关系关联单元202包括:
关系创建单元,用于根据所述实体之间关系数据,从候选池中选出待操作的批量的节点对,创建所述节点对的关系;
动态属性赋予第一单元,用于根据所述实体之间关系数据,为所述节点对的关系赋予动态属性。
在一实施例中,所述节点关系更新单元203包括:
第一节点对选取单元,用于当实体之间关系数据发生变化时,从候选池中选出待操作的节点对;
关系判断单元,用于判断所述节点对在所述图数据库中是否存在关系;
动态属性更新单元,用于若存在关系,则根据新的实体之间关系数据对所述节点对的关系进行更新,并为所述关系赋予新的动态属性;
动态属性赋予第二单元,用于若不存在关系,则创建所述节点对的关系,并为所述节点对的关系赋予动态属性。
在一实施例中,所述动态属性更新单元包括:
第一当前时间设置单元,用于将所述节点对的上一条关系的关系结束时间设置为当前时间;
节点对关系创建单元,用于为所述节点对创建新的关系,并根据新的实体之间关系数据将新的关系的节点生效时间设置为当前时间,并对新的关系的其他动态属性进行设置。
在一实施例中,所述节点关系删除单元204,包括:
第二节点对选取单元,用于当实体之间关系数据失效时,从候选池中选出待操作的节点对;
失效关系删除单元,用于根据当前实体之间关系数据对节点之间的关系进行删除,并更新失效关系的动态属性。
在一实施例中,所述实体数据查询单元205,包括:
查询请求获取单元,用于当接收到查询请求时,获取待查询的目标实体数据;
第一查询单元,用于根据所述目标实体数据在所述图数据库中查询与目标实体有关系的关联实体;
第二查询单元,用于在所述图数据库中查询所述目标实体与关联实体之间的关系;
查询返回单元,用于若所述关系中包含多条关系,则将当前关系作为实时关系状态返回,并将当前关系之前的所有关系作为历史关系状态返回。
本发明实施例还提供一种计算机设备,包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如上所述的基于图数据库的社区关系实时构建方法。
本发明实施例还提供一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如上所述的基于图数据库的社区关系实时构建方法。
说明书中各个实施例采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似部分互相参见即可。对于实施例公开的装置而言,由于其与实施例公开的方法相对应,所以描述的比较简单,相关之处参见方法部分说明即可。应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以对本发明进行若干改进和修饰,这些改进和修饰也落入本发明权利要求的保护范围内。
还需要说明的是,在本说明书中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的状况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。

Claims (10)

1.一种基于图数据库的社区关系实时构建方法,其特征在于,包括:
采集社区的实体数据以及实体之间关系数据,通过数据管道将所述实体数据以及实体之间关系数据导入图数据库中,并根据所述实体数据创建图数据库的节点;
根据所述实体之间关系数据对节点之间的关系进行创建,并为所述关系赋予动态属性;所述关系包括同类关系和异类关系;所述动态属性包括:关系生效时间和关系结束时间;
当实体之间关系数据发生变化时,根据新的实体之间关系数据对节点之间的关系进行更新,并为所述关系赋予新的动态属性;
当实体之间关系数据失效时,根据当前实体之间关系数据对节点之间的关系进行删除,并更新失效关系的动态属性;
当接收到查询请求时,获取待查询的目标实体数据,根据所述目标实体数据在所述图数据库中进行查询,获取目标实体的历史关系状态和实时关系状态。
2.根据权利要求1所述的基于图数据库的社区关系实时构建方法,其特征在于,所述采集社区的实体数据以及实体之间关系数据,通过数据管道将所述实体数据以及实体之间关系数据导入图数据库中,并根据所述实体数据创建图数据库的节点,包括:
采集社区的实体数据以及实体之间关系数据,并存储至关系型数据库;
构建数据管道,将关系型数据库中存储的实体数据以及实体之间关系数据导入所述图数据库;
根据所述实体数据创建图数据库的节点,并基于预先定义的配置信息为所述节点赋予相应的类型和属性。
3.根据权利要求2所述的基于图数据库的社区关系实时构建方法,其特征在于,所述根据所述实体之间关系数据对节点之间的关系进行创建,并为所述关系赋予动态属性,包括:
根据所述实体之间关系数据,从候选池中选出待操作的批量的节点对,创建所述节点对的关系;
根据所述实体之间关系数据,为所述节点对的关系赋予动态属性。
4.根据权利要求1所述的基于图数据库的社区关系实时构建方法,其特征在于,所述当实体之间关系数据发生变化时,根据新的实体之间关系数据对节点之间的关系进行更新,并为所述关系赋予新的动态属性,包括:
当实体之间关系数据发生变化时,从候选池中选出待操作的节点对;
判断所述节点对在所述图数据库中是否存在关系;
若存在关系,则根据新的实体之间关系数据对所述节点对的关系进行更新,并为所述关系赋予新的动态属性;
若不存在关系,则创建所述节点对的关系,并为所述节点对的关系赋予动态属性。
5.根据权利要求4所述的基于图数据库的社区关系实时构建方法,其特征在于,所述根据新的实体之间关系数据对节点之间的关系进行更新,并为所述关系赋予新的动态属性,包括:
将所述节点对的上一条关系的关系结束时间设置为当前时间;
为所述节点对创建新的关系,并根据新的实体之间关系数据将新的关系的节点生效时间设置为当前时间,并对新的关系的其他动态属性进行设置。
6.根据权利要求1所述的基于图数据库的社区关系实时构建方法,其特征在于,所述当实体之间关系数据失效时,根据当前实体之间关系数据对节点之间的关系进行删除,并更新失效关系的动态属性,包括:
当实体之间关系数据失效时,从候选池中选出待操作的节点对;
根据当前实体之间关系数据对节点之间的关系进行删除,并更新失效关系的动态属性。
7.根据权利要求1所述的基于图数据库的社区关系实时构建方法,其特征在于,所述当接收到查询请求时,获取待查询的目标实体数据,根据所述目标实体数据在所述图数据库中进行查询,获取目标实体的历史关系状态和实时关系状态,包括:
当接收到查询请求时,获取待查询的目标实体数据;
根据所述目标实体数据在所述图数据库中查询与目标实体有关系的关联实体;
在所述图数据库中查询所述目标实体与关联实体之间的关系;
若所述关系中包含多条关系,则将当前关系作为实时关系状态返回,并将当前关系之前的所有关系作为历史关系状态返回。
8.一种基于图数据库的社区关系实时构建装置,其特征在于,包括:
实体数据采集单元,用于采集社区的实体数据以及实体之间关系数据,通过数据管道将所述实体数据以及实体之间关系数据导入图数据库中,并根据所述实体数据创建图数据库的节点;
节点关系创建单元,用于根据所述实体之间关系数据对节点之间的关系进行创建,并为所述关系赋予动态属性;所述关系包括同类关系和异类关系;所述动态属性包括:关系生效时间和关系结束时间;
节点关系更新单元,用于当实体之间关系数据发生变化时,根据新的实体之间关系数据对节点之间的关系进行更新,并为所述关系赋予新的动态属性;
节点关系删除单元,用于当实体之间关系数据失效时,根据当前实体之间关系数据对节点之间的关系进行删除,并更新失效关系的动态属性;
实体数据查询单元,用于当接收到查询请求时,获取待查询的目标实体数据,根据所述目标实体数据在所述图数据库中进行查询,获取目标实体的历史关系状态和实时关系状态。
9.一种计算机设备,其特征在于,包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如权利要求1至7任一项所述的基于图数据库的社区关系实时构建方法。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1至7任一项所述的基于图数据库的社区关系实时构建方法。
CN202010819596.3A 2020-08-14 2020-08-14 一种基于图数据库的社区关系实时构建方法及其相关组件 Pending CN111966870A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202010819596.3A CN111966870A (zh) 2020-08-14 2020-08-14 一种基于图数据库的社区关系实时构建方法及其相关组件

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010819596.3A CN111966870A (zh) 2020-08-14 2020-08-14 一种基于图数据库的社区关系实时构建方法及其相关组件

Publications (1)

Publication Number Publication Date
CN111966870A true CN111966870A (zh) 2020-11-20

Family

ID=73387672

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010819596.3A Pending CN111966870A (zh) 2020-08-14 2020-08-14 一种基于图数据库的社区关系实时构建方法及其相关组件

Country Status (1)

Country Link
CN (1) CN111966870A (zh)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112749237A (zh) * 2020-12-30 2021-05-04 广州金越软件技术有限公司 一种基于图计算的人员关系构建和分析方法
CN113326276A (zh) * 2021-06-23 2021-08-31 北京金山数字娱乐科技有限公司 一种图数据库更新方法及装置
CN113497737A (zh) * 2021-05-13 2021-10-12 曙光信息产业(北京)有限公司 系统拓扑结构维护方法、装置、计算机设备和存储介质
CN114238268A (zh) * 2021-11-29 2022-03-25 武汉达梦数据技术有限公司 一种数据存储方法和装置
CN114528444A (zh) * 2022-02-25 2022-05-24 北京百度网讯科技有限公司 图数据处理方法、装置、电子设备和存储介质

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9967265B1 (en) * 2015-09-29 2018-05-08 EMC IP Holding Company LLC Detecting malicious online activities using event stream processing over a graph database
CN109871373A (zh) * 2019-01-31 2019-06-11 北京明略软件系统有限公司 一种数据存储方法和装置、计算机可读存储介质
CN109902130A (zh) * 2019-01-31 2019-06-18 北京明略软件系统有限公司 一种数据存储方法、数据查询方法和装置、存储介质
CN110457505A (zh) * 2019-07-04 2019-11-15 特斯联(北京)科技有限公司 基于图数据库进行关系挖掘的方法和装置
CN110688495A (zh) * 2019-12-09 2020-01-14 武汉中科通达高新技术股份有限公司 一种事件信息的知识图谱模型构建方法、装置、存储介质
CN111444287A (zh) * 2020-03-17 2020-07-24 北京齐尔布莱特科技有限公司 图数据库构建方法、关联信息查询方法、装置及计算设备

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9967265B1 (en) * 2015-09-29 2018-05-08 EMC IP Holding Company LLC Detecting malicious online activities using event stream processing over a graph database
CN109871373A (zh) * 2019-01-31 2019-06-11 北京明略软件系统有限公司 一种数据存储方法和装置、计算机可读存储介质
CN109902130A (zh) * 2019-01-31 2019-06-18 北京明略软件系统有限公司 一种数据存储方法、数据查询方法和装置、存储介质
CN110457505A (zh) * 2019-07-04 2019-11-15 特斯联(北京)科技有限公司 基于图数据库进行关系挖掘的方法和装置
CN110688495A (zh) * 2019-12-09 2020-01-14 武汉中科通达高新技术股份有限公司 一种事件信息的知识图谱模型构建方法、装置、存储介质
CN111444287A (zh) * 2020-03-17 2020-07-24 北京齐尔布莱特科技有限公司 图数据库构建方法、关联信息查询方法、装置及计算设备

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
张琳;熊斯攀;: "基于Neo4j的社交网络平台设计与实现", 情报探索, no. 08, 15 August 2018 (2018-08-15) *

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112749237A (zh) * 2020-12-30 2021-05-04 广州金越软件技术有限公司 一种基于图计算的人员关系构建和分析方法
CN113497737A (zh) * 2021-05-13 2021-10-12 曙光信息产业(北京)有限公司 系统拓扑结构维护方法、装置、计算机设备和存储介质
CN113326276A (zh) * 2021-06-23 2021-08-31 北京金山数字娱乐科技有限公司 一种图数据库更新方法及装置
CN113326276B (zh) * 2021-06-23 2024-07-16 北京金山数字娱乐科技有限公司 一种图数据库更新方法及装置
CN114238268A (zh) * 2021-11-29 2022-03-25 武汉达梦数据技术有限公司 一种数据存储方法和装置
CN114528444A (zh) * 2022-02-25 2022-05-24 北京百度网讯科技有限公司 图数据处理方法、装置、电子设备和存储介质
CN114528444B (zh) * 2022-02-25 2023-02-03 北京百度网讯科技有限公司 图数据处理方法、装置、电子设备和存储介质

Similar Documents

Publication Publication Date Title
CN111966870A (zh) 一种基于图数据库的社区关系实时构建方法及其相关组件
US20170357738A1 (en) Process for Merging Parametric Building Information Models
CN109840284B (zh) 家族亲缘关系知识图谱构建方法与系统
CN101901242A (zh) 联合的配置数据管理
CN110716950B (zh) 一种口径系统建立方法、装置、设备及计算机存储介质
KR100828404B1 (ko) 경계관찰질의를 이용한 데이터 스트림 처리 방법
US20180081975A1 (en) System and method for web content matching
CN101763575A (zh) 许可管理设备、许可管理方法以及计算机可读介质
CN111079131A (zh) 一种跨公司业务的权限授权与控制方法及系统
CN101604421A (zh) 一种基于网络的项目计划管理系统及方法
CN117035687A (zh) 一种电网业务固定资产流程配置方法、系统及计算机存储介质
JP5436309B2 (ja) データ処理装置及びデータ処理方法及びプログラム
US10803014B2 (en) Dynamic data relationships in a graph database
KR101183768B1 (ko) 통합 뷰 제공 시스템 및 방법 그리고 이에 적용되는 뷰 생성 기능을 가지는 서버
CN113239255B (zh) 异构数据资源的共享方法、装置、计算机设备及介质
CN112163010B (zh) 一种数据库的跨数据源查询方法及装置
CN112711623A (zh) 数据拉通方法及装置、存储介质、电子装置
CN105931018A (zh) 基于用户活动计划的活动时间推荐方法
CN109491800B (zh) 一种基于产品结构的档案推送系统及档案推送方法
JP2002041916A (ja) 施設予約システム及び施設予約方法
JPH09251469A (ja) セミカスタム・データベースシステム
Chen Using web-crawled data for urban housing research
CN108833466A (zh) 交通网络空间文本发布/订阅的系统及方法
CN109063220B (zh) 房屋数据处理方法及处理装置
CN111858845B (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