在Cypher中,如果不存在关系,我该如何建立关系;更新属性,如果它

时间:2012-07-06 00:33:36

标签: neo4j graph-databases cypher

在Neo4J的Cypher中,给定两个节点,如果它们之间没有关系,我想创建一个权重属性为1的关系(类型为Foo)。如果这种关系已经存在,我想增加它的权重属性。

在单个Cypher查询中有没有一种好方法可以做到这一点?谢谢!

编辑:一些其他细节: 节点已经创建,唯一且在索引中。

3 个答案:

答案 0 :(得分:44)

这正是我们在1.8中添加CREATE UNIQUE的原因。

START a=node(...), b=node(...)
CREATE UNIQUE a-[r:CONNECTED_TO]-b
SET r.weight = coalesce(r.weight?, 0) + 1

详细了解CREATE UNIQUE here,问号here和合并here

答案 1 :(得分:10)

要完成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

答案 2 :(得分:2)

自以后不建议使用CREATE UNIQUE(请参阅here),以供将来参考。看起来您可以使用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

因此,在这里,《神力女超人》至少与白羊战斗了一次,否则它将增加体重。