问题描述
我已经成功地使用 apoc 设置了动态属性,但是无法在 foreach 中使用 apoc..
相当于我想做的:
MATCH (n:Label {id: {id}})
MERGE (n)-[rel:HAS_RELATIONSHIP]->(UniqueNode:UniqueLabel)
WITH disTINCT rel,["DynamicProp1","DynamicProp2","DynamicProp3","LongListWouldratherNotDoOneAtATime"] as list
FOREACH (x in list |
FOREACH (o IN CASE WHEN NOT EXISTS(rel[x]) THEN [1] ELSE [] END |
SET rel[x]=false))
既然不能用 SET rel[x]=false 就得用了
CALL apoc.create.setRelProperty(rel,x,false)
但不会让我在 foreach 中使用它... 有没有办法做到这一点? TIA!
解决方法
您可以使用 UNWIND 获取列表中每个元素的一行,如果键不存在则过滤,然后使用 APOC 设置它。
MATCH (n:Label {id: {id}})
MERGE (n)-[rel:HAS_RELATIONSHIP]->(UniqueNode:UniqueLabel)
WITH rel
UNWIND ["DynamicProp1","DynamicProp2","DynamicProp3","LongListWouldRatherNotDoOneAtATime"] as propKey
WITH rel,propKey
WHERE NOT EXISTS(rel[propKey])
CALL apoc.create.setRelProperty(rel,propKey,false)
RETURN count(*)