neo4j批量插入效率低问题解决

1.问题场景

使用neo4j命令一条条插入数据时非常慢。有几万或者几十万数据时需要几个小时。

2.解决办法

	将数据写入到csv文件中,然后使用neo4j命令直接读取csv文件。(csv文件必须要有第一行的
字段名,user.csv放在/var/lib/neo4j/import/文件夹下,可通过配置修改默认存放目录)

2.1.例如有user.csv文件内容如下图所示,则导入命令为

LOAD CSV WITH HEADERS FROM 'file:///user.csv' AS row CREATE (:User {id: row.id, name: row.name, age: row.age, addtrss: row.addtrss, id_card: row.id_card, sex: row.sex, habbit: row.habbit})
包含开启事务,自动提交的命令
:auto USING PERIODIC COMMIT 10 LOAD CSV WITH HEADERS FROM 'file:///user.csv' AS row CREATE (:User {id: row.id, name: row.name, age: row.age, addtrss: row.addtrss, id_card: row.id_card, sex: row.sex, habbit: row.habbit})
在这里插入图片描述
在这里插入图片描述

2.2.可以只插入自己需要的字段的数据,例如还是上面user.csv文件,但只需要其中id,name,age字段,则可以修改语句为:

LOAD CSV WITH HEADERS FROM 'file:///user.csv' AS row CREATE (:User {id: row.id, name: row.name, age: row.age})

2.3.读取一万条数据测试

可以看到插入15000条数据只用了1秒钟。

在这里插入图片描述

2.4.导入关系

	请确保在执行导入命令之前,已经在Neo4j数据库中创建了适当的标签和索引,以便正确地导入数据。

LOAD CSV WITH HEADERS FROM 'file:///your_file.csv' AS row MATCH (sourceNode:Label1 {property1: row.sourceProperty}) MATCH (targetNode:Label2 {property2: row.targetProperty}) CREATE (sourceNode)-[:RELATIONSHIP_TYPE]->(targetNode)

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Neo4j批量导入是指将大批量数据快速导入到Neo4j数据库中的操作。有几种方法可以实现批量导入,其中最常用的是使用load csv和neo4j-admin import工具。load csv是一种在线导入方式,不需要停止Neo4j的运行,支持增量导入数据,使用的是cypher语言。而neo4j-admin import则需要生成一个新的数据库文件,并且需要重启Neo4j,不支持增量导入,但是导入速度非常快,可能比load csv快100倍以上。 如果使用neo4j-admin import进行批量导入,可以按照以下步骤进行操作: 1. 准备好要导入的数据文件,格式为CSV。可以使用命令行工具进入Neo4j的安装目录,并执行以下指令进行导入: 如果使用load csv进行批量导入,可以按照以下步骤进行操作: 1. 准备好要导入的数据文件,格式为CSV。 2. 在Neo4j的cypher shell中,可以执行类似以下的cypher语句进行导入: LOAD CSV WITH HEADERS FROM "file:///data.csv" AS row CREATE (:Node {property: row.property}) [2] 总之,根据不同的需求和情况,可以选择合适的方法进行Neo4j批量导入。如果需要快速导入大量数据,可以使用neo4j-admin import工具;如果需要在线导入并支持增量导入,可以使用load csv方法。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [neo4jneo4j批量导入neo4j-import (五)](https://blog.csdn.net/sinat_26917383/article/details/82424508)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Neo4j笔记(三)Neo4j批量导入数据](https://blog.csdn.net/haveanybody/article/details/90518235)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Neo4j批量导入](https://download.csdn.net/download/qingxincao/10513243)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值