微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决如何在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(*)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。