密码更改地图上的密钥名称

问题描述

在 neo4j 中使用 cypher,更改地图上具有特定名称的所有键的最佳方法是什么? 例如,在下面的代码中,我想替换 theOrigKeytheNewKey

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

如果这些是节点,我可以只使用 SETREMOVE 语句,但这些只是映射。将它们转换为 JSON 就好了,如果这有帮助的话……该过程的下一步无论如何都会将它们转换为 JSON。

在使用 cypher 的同时有没有什么好的方法可以做到这一点?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)