gpt4 book ai didi

neo4j - 使用 Cypher 修改 Neo4j 中的关系链

转载 作者:行者123 更新时间:2023-12-01 16:27:52 25 4
gpt4 key购买 nike

我在生产数据库中创建了错误的关系,需要更新关系才能纠正问题 - 就是这样:

我的应用程序中有一个功能,允许用户复制节点(原始节点)。当用户复制节点时,在原始节点和副本之间创建关系。复制副本时出现错误。应该从第二个副本创建到第一个原始节点的关系,但它是在副本 1 和副本 2 之间创建的:

(Original)-->(Copy1)-->(Copy2)-->(Copy3) ... etc

这应该是:

            (Copy2)
^
|
(Copy3)<--(Original)-->(Copy1)

如何更新关系链以指向原始关系链?

最佳答案

我举了一个小例子,因为我不知道你的具体数据模型。假设您的图形数据库中存在以下场景:

CREATE (original:Thing)-[:HAS_COPY]->(copy1:Thing)-[:HAS_COPY]->(copy2:Thing)-[:HAS_COPY]->(copy3:Thing)

可以在启动链的节点周围收集此链的副本:

MATCH (copy:Thing)<-[rels:HAS_COPY*]-(original)
WHERE NOT ()-[:HAS_COPY]->(original)
FOREACH (r IN rels | DELETE r)
CREATE (original)-[:HAS_COPY]->(copy)

在这里,我们通过任意数量的 HAS_COPY 关系 (*) 匹配连接到原始版本的每个副本。我们知道原始节点,因为它本身不是任何东西的副本。然后,对于副本和原始文件之间的每个关系,我们删除它们并直接为原始文件创建一个新的关系。

我对此进行了一些测试,它应该可以正常工作,但请在将其应用到您的生产数据库之前对其进行测试。

关于neo4j - 使用 Cypher 修改 Neo4j 中的关系链,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23745286/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com