在 Neo4j 中,是否有一种最佳方法可以创建面向未来的无期限关系?

如何解决在 Neo4j 中,是否有一种最佳方法可以创建面向未来的无期限关系?

我只是在学习 Neo4j 并想创建一个系统,让我拥有每个人都可以有父母或孩子的主题,但它是父母还是孩子并不总是很明显,而且关系并不总是相同类型。

如果您查看 Neo4j 的示例 here,它使用以下代码:

(:Person {name: string})-[:ACTED_IN {roles: [string]}]->(:Movie {title: string,released: number})

当您知道它是电影时,这会起作用。在这种情况下,节点是 Movie 类型。如果你正在创作的东西今天有电影,但明天有一个完全不同的主题,比如 CEO,那么 movie 和关系 ACTED_IN 不再相关。当人们希望他们的代码随着他们的“主题”或节点类型的变化而可管理时,他们通常如何处理这些场景,尤其是当节点类型从一开始就可以是更通用的 thing 时。

也许是这样的:

Tom Hanks IS_CHILD_OF Forrest Gump 而不是 Tom Hanks ACTED_IN Forrest Gump

但是既然关系名称如此通用,您如何确定此关系的方向?演员是他们电影的孩子,还是电影现在是演员的孩子?

我的主要问题是,我如何才能在未来证明我有一个通用的 thing 而不是 movieceohot_sauce 节点。因此,如果明天的主题是 CEO,那么您有 Tim Cook IS_CHILD_OF Apple 或类似的内容吗?

另外,这只是非常低效吗?如果是这样,那么如果节点类型和关系的名称非常动态,您如何跟踪这些并知道查询什么以及何时查询?

解决方法

在我看来,面向未来是一条危险的道路:-) 然而,如果您正在构建的系统是通用的,那么您必须根据一些核心概念进行建模。具有父子关系的主题,或相互关联的页面。这些足够好,可以用来建模,因为您可以针对您提出的问题测试模型。

对于图形建模,问题/用例出现在模型之前,所以我会从那里开始 - 您希望图形回答什么?示例:哪些页面与特斯拉相关?或者,主题 A 和主题 B 有什么关系?如果没有这些问题,您的图形模型的范围可能从有点足够到性能不佳,再到适合实际情况。 一旦你有问题,那么实体/节点应该立即开始向你跳来跳去,以及关系。

我能想到的最接近现实世界的例子是 POLE model,它基于四种类型的概念 - 人、对象、位置、事件。这个域中的所有东西都被插入到这四个中的一个中。这使模型具有某种“通用”的风格,同时仍允许进行合理的查询,例如在该位置发生了哪些事件涉及此人和该对象。

您可以进一步将其抽象为一个名为 Entity 的单个节点类型和一个名为 RELATED 或类似的关系类型,但随后您需要构建一整层元数据来理解该结构的真正含义。您的数据库将成为链接信息片段的存储,您将业务逻辑委托给应用程序,根据元数据形成查询。也许这就是您所追求的。

在性能方面,很难说,因为整个图看起来都一样——也许你有非常密集的节点,也许你必须遍历这些密集节点的每个关系并通过特性。如果您只有一个标签,索引将没有多大用处。 所以本质上,这个模型绝对是可能的,但如果这是你要走的路,那么值得检查图数据库给你的领域/应用程序带来了什么,以确保这些权衡是值得的。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)> insert overwrite table dwd_trade_cart_add_inc > select data.id, > data.user_id, > data.course_id, > date_format(
错误1 hive (edu)> insert into huanhuan values(1,'haoge'); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive> show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 <configuration> <property> <name>yarn.nodemanager.res