使用Cypher修改Neo4j中的关系链

时间:2014-05-19 19:02:25

标签: neo4j cypher

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

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

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

这应该是:

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

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

1 个答案:

答案 0 :(得分:5)

我做了一个小例子,因为我不知道你的具体数据模型。在图表数据库中给出以下情感:

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关系(*)匹配与原始文件相关联的每个副本。我们知道的原始节点因为它不是任何东西的副本。然后,对于副本和原始副本之间的每个关系,我们删除它们并直接创建一个新的òne。

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