apoc.refactor.collapseNode

详细信息

语法

apoc.refactor.collapseNode(nodes, relType) :: (input, output, error)

描述

折叠给定的 NODE 并将其替换为指定类型的 RELATIONSHIP

输入参数

名称

类型

描述

节点

ANY

要折叠的节点。节点可以是 STRING (elementId())、INTEGER (id())、NODELIST<STRING | INTEGER | NODE> 类型。

relType

STRING

生成的关联关系类型名称。

返回参数

名称

类型

描述

input

INTEGER(整数)

给定关联关系的 ID。

输出

RELATIONSHIP

更新类型后的新关联关系的 ID。

错误 (error)

STRING

如果发生错误,则返回错误消息。

使用 Cypher 重构节点

在 Cypher 中,无需使用 APOC 即可动态引用节点标签和关系类型。

用于动态创建、匹配和合并标签与类型的 Cypher 语法
CREATE (n1:$(label))-[r:$(type)]->(n2:$(label))
MERGE (n1:$(label))-[r:$(type)]->(n2:$(label))
MATCH (n1:$(label))-[r:$(type)]->(n2:$(label))

动态计算出的类型必须求值为 STRINGLIST<STRING>。更多信息,请参阅 Cypher 手册 → CREATEMERGEMATCH

使用 CALL {…​} IN CONCURRENT TRANSACTIONS 可以在 Cypher 中实现批处理和并行执行。有关更多信息,请参阅 事务中的 CALL 子查询 → 并发事务

使用示例

本节中的示例基于以下示例图

CREATE (flight:Flight {number: "BA001"})
CREATE (origin:Airport {code: "LHR"})
CREATE (destination:Airport {code: "AMS"})
CREATE (flight)<-[:OUT]-(origin)
CREATE (flight)-[:IN]->(destination);

以下查询将 Flight 节点折叠,并使用 APOC 和 Cypher 将其替换为 CONNECTED_TO 关系

apoc.refactor.collapseNode
MATCH (flight:Flight {number: "BA001"})
CALL apoc.refactor.collapseNode([flight],'CONNECTED_TO')
YIELD input, output
RETURN input, output;
使用 Cypher
MATCH (flight:Flight {number: "BA001"})
CALL (flight) {
    MATCH p=(a)-[]-(f)-[]-(b)
    WITH p, a, f, b LIMIT 1
    CREATE (a)-[r:CONNECTED_TO]->(b)
    SET r = properties(f)
    DETACH DELETE f
    RETURN r AS newRel
}
RETURN newRel
结果
input 输出

10

[:CONNECTED_TO {number: "BA001"}]

如果我们执行此查询,将得到以下图形

apoc.refactor.collapseNode