你遇到了一个常见的误解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)