Cypher - 在两个节点阵列之间创建关系的最佳方式

时间:2014-07-07 20:30:12

标签: neo4j cypher

我有两个节点数组

TYPE1 : [Node1, Node2, ...NodeN]
TYPE2 : [OtherNode1, OtherNode2....OtherNodeN]

我尝试将每个TYPE1节点连接到相应的TYPE2节点,如下所示。

(Node1) -[:RELATED_TO] -> (OtherNode1)

这是一个简单的一对一的通信。

我用过

MATCH (x:TYPE1),(y:TYPE2)
with x, y
with COLLECT(x) as n1, COLLECT(y) as n2
FOREACH(i in RANGE(0, 9) |
   CREATE (n1[i])-[:RELATED_TO]->(n2[i])
)

失败

错误:输入无效' [':期望标识符字符,节点标签,属性映射,')'或关系模式(第4行,第21栏)

我有两个问题。

  1. 我在查询中做错了什么?

  2. 完成我所做的事情的最佳方式是什么?

  3. 非常感谢!

1 个答案:

答案 0 :(得分:5)

考虑以下示例数据:

FOREACH (i IN range(1,10) | CREATE (:TYPE1), (:TYPE2))

因为您不想通过任何属性订购您的馆藏,所以您只需按MATCH找到的节点加入节点即可。以下查询将会(我认为)你正在尝试做什么,虽然它不够优雅:

MATCH (x:TYPE1), (y:TYPE2)
WITH COLLECT(DISTINCT x) AS n1, COLLECT(DISTINCT y) AS n2
WHERE LENGTH(n1) = LENGTH(n2)
FOREACH (i IN RANGE(0, LENGTH(n1) - 1) |
    FOREACH (node IN [n1[i]] |
        FOREACH (othernode IN [n2[i]] |
            MERGE (node)-[:RELATED_TO]-(othernode)
        )
    )
)

浏览器视图后查询:

enter image description here