Neo4j数据建模优化:双向关系

原文链接:http://graphaware.com/neo4j/2013/10/11/neo4j-bidirectional-relationships.html

我们通常会将现实生活中的关系型数据,通过一定的方式,转化为图形化的结构存储起来。尽管图形化的结构相比于表结构更加直观,但也存在一些常见的误区。在这篇博文中,我们来讨论其中的一个容易让人混淆的概念:双向关系。

单向关系

在Neo4j中,所有的关系都必须有一个类型来进行区分,同时,也必须有一个方向。通常来说,关系的方向同样会包含一些信息。换句话来说,如果没有方向,一些关系的意义就会变得模糊。打个比方,下面的图结构表明了在冰球比赛中,Czech Republic队击败了Sweden。假如这个关系的方向反过来,那么就意味着Sweden胜利了。如果没有任何方向,那么这个关系的意义就变得很模糊了,因为没有办法区分出到底是哪个队获胜了。

这里写图片描述

可以发现,在这里,一个单向的关系同时也表明了一个反向关系的存在,正如下一张图所示。通常情况下都是如此。再打个比方:昆汀·塔伦蒂诺导演了《低俗小说》,同时也意味着《低俗小说》的导演是昆汀·塔伦蒂诺。

这里写图片描述

在设计这类模型的时候,同时创建两个方向的关系是一个常见的错误。因为一个关系可以同时意味着另一个关系,因此,不论在空间还是遍历时间上,这都是一种浪费。Neo4j可以在任何方向上进行遍历。更重要的是,Neo4j存储数据的方式,使得遍历的速度和关系的方向没有任何关系

双向关系

有一些关系在设计上就是双向的。一个很典型的例子就是Fackbook或者现实生活中的朋友关系。这种关系是相互的:当某个人是你的朋友,你也是他的朋友。根据我们对模型理解的不同,也可以说这种关系是无向的。

GraphAware和Neo Technology是合作公司。因为这是一个相互的关系,我们可以分别构建双向或者无向的关系模型。

这里写图片描述

但是,因为Neo4j并不支持双向或者无向的关系,初学者往往会构造出下面这样的结构来。这和上述冰球的模型犯了同样的错误:多了一种不需要的关系。

这里写图片描述

Neo4j的API允许开发人员在查询的时候完全忽略关系的方向。比如,在Neo4j的查询语言Cypher中,查询Neo Technology的全部合作公司的语句可以大致如下:

MATCH (neo)-[:PARTNER]-(partner)

查询结果会和下面两条语句执行并合并后的结果完全一致:

MATCH (neo)-[:PARTNER]->(partner) and MATCH (neo)<-[:PARTNER]-(partner)

因此,构建合作关系正确(至少是最有效)的方式就是用一个单向的关系,而且方向可以任意

这里写图片描述

结论

在Neo4j中,遍历关系的任何一个方向所需的时间是相同的。进一步说,方向可以被完全忽略。因此,当单向的关系可以同时代表另一个方向的关系的时候,没有必要同时创建两个方向的关系。

Neo4j中建立两层关系可以通过使用Cypher查询语言来实现。首先,您可以使用CREATE语句创建两个节点,然后使用CREATE语句创建它们之间的关系。例如,假设我们有两个节点A和B,我们想要在它们之间建立两层关系。以下是一个示例Cypher查询: ``` CREATE (a:Node {name: 'A'}) CREATE (b:Node {name: 'B'}) CREATE (a)-\[:RELATIONSHIP1\]->(:Node {name: 'C'}) CREATE (b)-\[:RELATIONSHIP2\]->(:Node {name: 'D'}) ``` 在上面的查询中,我们首先创建了两个节点A和B。然后,我们使用CREATE语句创建了两个新节点C和D,并将它们与节点A和B之间的关系建立起来。关系1是从节点A指向节点C,关系2是从节点B指向节点D。 另外,您还可以使用MATCH语句来查询与节点A直接或间接相连的所有节点。例如,以下是一个示例查询: ``` MATCH (a:Node {name: 'A'})-\[*1..2\]-(b) RETURN b ``` 在上面的查询中,我们使用MATCH语句找到了与节点A直接或间接相连的所有节点。通过使用\[*1..2\],我们指定了关系的层数范围为1到2层。这意味着我们将返回与节点A直接相连的节点以及与节点A通过一层关系相连的节点。 请注意,上述示例仅用于演示目的。实际使用时,您需要根据您的数据模型和需求进行适当的调整。 #### 引用[.reference_title] - *1* [neo4j 关系属性_Neo4j:特定关系与一般关系+属性](https://blog.csdn.net/dnc8371/article/details/107262530)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Neo4j数据建模优化双向关系](https://blog.csdn.net/lzw17750614592/article/details/89703915)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [springboot+neo4j+d3项目之neo4j基础学习(五)neo4j查询节点的多层关系](https://blog.csdn.net/wavehaha/article/details/111592161)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值