我有两个节点数组
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栏)
我有两个问题。
我在查询中做错了什么?
完成我所做的事情的最佳方式是什么?
非常感谢!
答案 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)
)
)
)
浏览器视图后查询: