当前位置:  开发笔记 > 编程语言 > 正文

MERGE的Cypher'Node已经存在'问题

如何解决《MERGE的Cypher'Node已经存在'问题》经验,为你挑选了1个好方法。



1> Nicole White..:

你遇到了一个常见的误解MERGE.MERGE合并您在单个子句中指定的所有内容MERGE.所以操作顺序是:

    搜索:Location具有您指定的所有属性的节点.

    如果找到,则返回节点.

    如果未找到,请创建节点.

您的问题发生在步骤3.因为具有您指定的所有属性的节点不存在,所以它转到步骤3并尝试创建具有所有这些属性的节点.那是你的唯一性约束被违反的时候.

最佳做法是合并您已限制为唯一的属性,然后使用它SET来更新其他属性.在你的情况下:

MERGE (l:Location {address:"36350 Van Dyke Ave"})
SET l.location_name = "Starbucks",
     l.city = "Sterling Heights"
...

同样的逻辑将适用于您稍后在查询中合并的关系.如果整个模式不存在,它将尝试创建整个模式.这就是为什么你应该坚持以下的最佳做法:

MERGE (node1:Label1 {unique_property: "value"})
MERGE (node2:Label2 {unique_property: "value"})
MERGE (node1)-[:REL]-(node2)


这是一个非常有用的答案,我在尝试抱怨的"LOAD CSV"后发现了这个答案.
推荐阅读
mobiledu2402851323
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有