Neo4j出口&导入数据

时间:2015-01-30 23:40:08

标签: java import neo4j export

是否有一种使用Neo4j Java API将一些数据从一个数据库迁移到另一个数据库的好方法?我的用例是将几千个节点加载到一个临时数据库中,进行一系列转换,然后将结果导出到主数据库并删除临时数据库。

我不想破坏目标数据库中的数据,这是一个附加过程。我在互联网上看到很多人(例如here)说“只是将数据目录复制到新位置”,但当然会破坏目的地。

更新 - 我尝试了neo4j-shell -path tmpDir -c "DUMP MATCH n RETURN n;" | neo4j-shell -path dbDir -file -,但它确实非常慢。生成输出似乎足够快,但即使在一个新的空数据库中,它仍然是冰冷的。

1 个答案:

答案 0 :(得分:7)

有很多选择:

  1. 您可以在java副本中打开两个neo4j数据库,并使用Java API将节点和关系从一个转移到另一个。

  2. 在初级播种的低级别上,您可以使用batch-inserter-apis执行相同操作,就像我在此处所做的那样:https://github.com/jexp/store-utils/tree/21

  3. 您可以将密码结果导出为CSV(例如,从浏览器中),然后使用例如LOAD CSV

  4. 再次导入
  5. 您可以使用neo4j-shell-tools进行某些导入导出任务,例如导出到GraphML或CSV并再次导回