是否有一种使用Neo4j Java API将一些数据从一个数据库迁移到另一个数据库的好方法?我的用例是将几千个节点加载到一个临时数据库中,进行一系列转换,然后将结果导出到主数据库并删除临时数据库。
我不想破坏目标数据库中的数据,这是一个附加过程。我在互联网上看到很多人(例如here)说“只是将数据目录复制到新位置”,但当然会破坏目的地。
更新 - 我尝试了neo4j-shell -path tmpDir -c "DUMP MATCH n RETURN n;" | neo4j-shell -path dbDir -file -
,但它确实非常慢。生成输出似乎足够快,但即使在一个新的空数据库中,它仍然是冰冷的。
答案 0 :(得分:7)
有很多选择:
您可以在java副本中打开两个neo4j数据库,并使用Java API将节点和关系从一个转移到另一个。
在初级播种的低级别上,您可以使用batch-inserter-apis执行相同操作,就像我在此处所做的那样:https://github.com/jexp/store-utils/tree/21
您可以将密码结果导出为CSV(例如,从浏览器中),然后使用例如LOAD CSV
您可以使用neo4j-shell-tools进行某些导入导出任务,例如导出到GraphML或CSV并再次导回