19

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

有没有在单个 Cypher 查询中执行此操作的好方法?谢谢!

编辑:一些额外的细节:节点已经创建,唯一的,并且在索引中。

4

3 回答 3

45

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

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

阅读更多关于CREATE UNIQUE 这里,问号在这里,并在这里合并。

于 2012-07-06T04:51:05.020 回答
11

为了完成 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
于 2014-05-01T03:08:15.617 回答
4

为了将来参考,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

所以在这里,神奇女侠至少与白羊座战斗过一次,否则它会增加重量。

于 2019-04-10T22:56:54.547 回答