问题描述
在 neo4j 中使用 cypher,更改地图上具有特定名称的所有键的最佳方法是什么? 例如,在下面的代码中,我想替换 theOrigKey 和 theNewKey。
WITH {dummyKey:1,theOrigKey:[
{lvl2DummyKey:2,theOrigKey:[ {lvl3DummyKey:3.1},{lvl3DummyKey:3.2} ]
},{lvl2DummyKey:2,{lvl3DummyKey:3.2} ]
}
]} AS myMap
RETURN myMap
变成
WITH {dummyKey:1,theNewKey:[
{lvl2DummyKey:2,theNewKey:[ {lvl3DummyKey:3.1},{lvl3DummyKey:3.2} ]
}
]} AS myMap
RETURN myMap
我想过将地图转换为字符串,替换文本,然后再将其转换回来。但是,这似乎效率低下,并且如果密钥可能出现在数据的其他地方(无论如何它对我也不起作用),则不起作用。
WITH apoc.convert.toString(myMap) AS strMyMap
WITH replace(strMyMap,"theOrigKey","theNewKey") AS strMyMap
WITH apoc.convert.toMap(strMyMap) AS MyNewMap
RETURN MyNewMap
如果这些是节点,我可以只使用 SET
和 REMOVE
语句,但这些只是映射。将它们转换为 JSON 就好了,如果这有帮助的话……该过程的下一步无论如何都会将它们转换为 JSON。
在使用 cypher 的同时有没有什么好的方法可以做到这一点?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)