在 Neo4J 的 Cypher 中,给定两个节点,如果它们之间没有关系,我想创建一个权重属性为 1 的关系(类型为 Foo)。如果这种关系已经存在,我想增加它的权重属性。
有没有在单个 Cypher 查询中执行此操作的好方法?谢谢!
编辑:一些额外的细节:节点已经创建,唯一的,并且在索引中。
在 Neo4J 的 Cypher 中,给定两个节点,如果它们之间没有关系,我想创建一个权重属性为 1 的关系(类型为 Foo)。如果这种关系已经存在,我想增加它的权重属性。
有没有在单个 Cypher 查询中执行此操作的好方法?谢谢!
编辑:一些额外的细节:节点已经创建,唯一的,并且在索引中。
为了完成 Andres 的回答,属性末尾的问号现在是 Neo4j 2 的错误。所以请求将是:
MATCH a, b
WHERE a(...) AND b(...)
CREATE UNIQUE a-[r:CONNECTED_TO]->b
SET r.weight = coalesce(r.weight, 0) + 1
为了将来参考,CREATE UNIQUE 已被弃用(请参阅此处)。看起来你可以用 MATCH 和 MERGE 做类似的事情:
MATCH (a:Person {name: 'Wonder Woman'})
MERGE (b:Person {name: 'Aries'})
MERGE (a)-[r:FOUGHT]->(b)
ON CREATE SET r.weight = 1
ON MATCH SET r.weight = r.weight + 1
所以在这里,神奇女侠至少与白羊座战斗过一次,否则它会增加重量。