如何在foreach中设置动态属性?

问题描述

我已经成功地使用 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(*)