使用变量 MATCH 标签动态创建 Neo4j/Cypher 关系

joh*_*aco 4 neo4j

我需要在现有节点之间创建关系,并尝试按照 youtube 创建动态节点和关系:https://www.youtube.com/watch? v=KsAb8QHClNg 几次,但我不认为它们涵盖了我的使用案件。

示例数据:

SOURCE  TARGET  LABEL   TYPE    SOURCE_TYPE TARGET_TYPE SOURCE_KEY  TARGET_KEY  PHLEVEL COLOR   SIZE    SCOPE
16      1   ERKRS_ROOT  DIRECTED    ERKRS   ROOT    ERKRS_R300  ROOT_EC3_800    0       #808080 1   FALSE
12      1   ERKRS_ROOT  DIRECTED    ERKRS   ROOT    ERKRS_INT1  ROOT_EC3_800    0       #808080 1   FALSE
51      1   KKBER_ROOT  DIRECTED    KKBER   ROOT    KKBER_GVK1  ROOT_EC3_800    0       #808080 1   FALSE
31      1   KKBER_ROOT  DIRECTED    KKBER   ROOT    KKBER_6000  ROOT_EC3_800    0       #808080 1   FALSE
71      1   FIKRS_ROOT  DIRECTED    FIKRS   ROOT    FIKRS_1000  ROOT_EC3_800    0       #808080 1   FALSE
334     9   KOKRS_ERKRS DIRECTED    KOKRS   ERKRS   KOKRS_2000  ERKRS_IDEA      1       #808080 1   FALSE
335     9   KOKRS_ERKRS DIRECTED    KOKRS   ERKRS   KOKRS_2200  ERKRS_IDEA      1       #808080 1   FALSE
342     9   KOKRS_ERKRS DIRECTED    KOKRS   ERKRS   KOKRS_4500  ERKRS_IDEA      1       #808080 1   FALSE
Run Code Online (Sandbox Code Playgroud)

我已使用 apoc.create.node 和我的节点文件成功动态创建了节点。节点标签 = SOURCE_TYPE 或 TARGET_TYPE。节点 KEY 属性 = SOURCE_KEY 或 TARGET_KEY。该关系是 LABEL 列。

现在,我面临着创建关系的挑战,因为 MATCH 子句不接受我的文件中的标签 - 这是我的脚本:

USING PERIODIC COMMIT 500 LOAD CSV WITH HEADERS  FROM 'file:///IDES__Edges1.csv' AS line
MATCH (x:line.SOURCE_TYPE {key:line.SOURCE_KEY}), (y:line.TARGET_TYPE {key:line.TARGET_KEY})
CALL apoc.create.relationship(x, line.LABEL, y) YIELD rel RETURN count(*)
Run Code Online (Sandbox Code Playgroud)

我收到这个错误...

    Neo.ClientError.Statement.SyntaxError: Invalid input '.': expected an identifier character, whitespace, NodeLabel, a property map, ')' or a relationship pattern (line 2, column 15 (offset: 103))
"   MATCH (x:line.SOURCE_TYPE {key:line.SOURCE_KEY}), (y:line.TARGET_TYPE {key:line.TARGET_KEY})"
Run Code Online (Sandbox Code Playgroud)

有谁对如何解决这个问题有任何想法?我已经非常接近解决我的问题了!任何帮助表示赞赏。约翰

Inv*_*con 5

这说明了为什么建议按节点类型处理单独的 CSV 文件,以便您始终能够知道将什么标签硬编码到查询中。

这是 Cypher 的要求,因为当标签被硬编码时,规划器会利用数据库中的元数据来帮助如何有效地规划查询执行(动态标签的评估必须在执行期间进行......这对于必须执行的规划器来说毫无用处)在执行之前规划查询)。

对于这种情况,最好向所添加的每个类型的所有节点添加第二个更通用的标签,然后使用该key属性和该通用标签创建索引,并在以下情况下使用该通用标签进行查找:建立关系。

因此,在应用通用标签(现在我们称之为 :Node)并在 :Node(key) 上创建索引后,就很简单了:

USING PERIODIC COMMIT 500 LOAD CSV WITH HEADERS  FROM 'file:///IDES__Edges1.csv' AS line
MATCH (x:Node {key:line.SOURCE_KEY}), (y:Node {key:line.TARGET_KEY})
CALL apoc.create.relationship(x, line.LABEL, y) YIELD rel 
RETURN count(*)
Run Code Online (Sandbox Code Playgroud)

当然,这假设键在具有所有给定标签的所有节点中是唯一的。如果情况并非如此,则需要采用不同的方法。