apoc.refactor.invert

详细信息

语法

apoc.refactor.invert(rel, config) :: (input, output, error)

描述

反转给定 RELATIONSHIP(关系)的方向。

输入参数

名称

类型

描述

关系

RELATIONSHIP

要反转的关系。

config

MAP

{ failOnErrors = false :: BOOLEAN }。请注意,虽然建议使用 { failOnErrors = true } 以确保事务一致性并防止部分更改应用,但这不是默认设置,因为这可能会破坏现有的实现。APOC 2025.01 中引入

返回参数

名称

类型

描述

input

INTEGER(整数)

原始实体的内部 ID。

输出

RELATIONSHIP

复制后的实体。

错误 (error)

STRING

复制过程中发生的任何错误。

使用示例

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

CREATE (mark:Person {name: "Mark", city: "London"})
CREATE (jennifer:Person {name: "Jennifer", city: "St Louis"})
CREATE (mark)-[:FOLLOWS]->(jennifer);

以下示例反转了 FOLLOWS 关系,通过 APOC 和 Cypher 将 Jennifer 设为起始节点

apoc.refactor.invert
MATCH ()-[rel:FOLLOWS]->()
CALL apoc.refactor.invert(rel, { failOnErrors = true })
YIELD input, output
RETURN input, output;
使用 Cypher
MATCH (startNode)-[rel:FOLLOWS]->(endNode)
CALL (*) {
    WITH id(rel) AS oldId, properties(rel) AS relProps, type(rel) AS relType
    DELETE rel
    MERGE (startNode)<-[newRel:$(relType)]-(endNode)
    SET newRel = relProps
    RETURN oldId AS oldId, newRel AS newRel
}
RETURN oldId, newRel;
结果
input 输出

14

[:FOLLOWS]

我们可以通过运行以下查询列出所有的 Person 节点

MATCH path = ()-[rel:FOLLOWS]->()
RETURN path;
结果
path

(:Person {name: "Jennifer", city: "St Louis"})-[:FOLLOWS]→(:Person {name: "Mark", city: "London"})

APOC 不会反转类型;相反,它会以期望的方向添加一个新的关系并删除原始关系。