neo4j数据库的导入和导出

平时的工作中,我们可能需要将一个数据库的文件导出,然后再将这个文件导入到另一个数据库中,实现数据库的迁移。

本文中主要介绍neo4j的官方管理工具neo4j-admin,来对neo4j数据库文件进行导入和导出。

1.文件导出

(1).停止服务

进入到需导出文件的neo4j的bin目录下,执行 ./neo4j stop 命令先停止服务。

bash 复制代码
./neo4j stop

(2).导出文件

bash 复制代码
neo4j-admin database dump myneo4jdb --to-path=/var/lib/neo4j/backups/

以上的命令会将myneo4jdb这个数据库导入到 /var/lib/neo4j/backups/这个目录下。如果该目录不存在,需要自己创建。最后会导出.dump后缀的数据文件。

(3).启动服务

数据库文件导出完成后,就可以启动服务了。

bash 复制代码
./neo4j start

(4).docker导出

如果我们的neo4j数据库是使用docker部署的话,以下是使用docker命令的方式来导出文件。

停止服务

bash 复制代码
docker stop neo4j_service

导出文件

bash 复制代码
docker run --interactive --tty --rm \
  -v=$(pwd)/db-data:/var/lib/neo4j/data \
  -v=$(pwd)/db-export:/var/lib/neo4j/backups/ \
  neo4j:5.26.2 \
  neo4j-admin database dump myneo4jdb --to-path=/var/lib/neo4j/backups/

以上docker命令中宿主机和docker容器映射挂载了两个目录:1.neo4j数据库数据文件的挂载目录。2.导出完成后导出文件存放的挂载目录。可以看出本例中使用的是5.26.2版本的neo4j数据库镜像。导出命令执行完成后,我们可以在宿主机的db-export目录下看到导出的文件。

启动服务

bash 复制代码
docker start neo4j_service

2.文件导入

(1).停止服务

bash 复制代码
./neo4j stop

(2).导入文件

bash 复制代码
neo4j-admin database load --from-path=/var/lib/neo4j/import/ myneo4jdb --overwrite-destination=true

上述的导入命令是把/var/lib/neo4j/import/目录下的数据库文件导入到目标库,导入后数据库的名称是myneo4jdb,参数**--overwrite-destination=true**的作用是,如果数据库中已经存在了myneo4jdb数据库,则会将myneo4jdb覆盖。

(3).启动服务

复制代码
./neo4j start

(4).docker导入

停止服务

bash 复制代码
docker stop neo4j_service

导入文件

bash 复制代码
  docker run --rm -it \
  -v=$(pwd)/db-data:/var/lib/neo4j/data \
  -v=$(pwd)/import:/var/lib/neo4j/import \
  neo4j:5.26.2 \
  neo4j-admin database load --from-path=/var/lib/neo4j/import/ myneo4jdb --overwrite-destination=true

以上docker命令中宿主机和docker容器映射也挂载了两个目录:1.neo4j数据库数据文件的挂载目录。2.需导入数据库文件放置的目录。我们需要把要导入的数据库文件,放到宿主机的import目录下。

启动服务

bash 复制代码
docker start neo4j_service

3.导入特定账户的数据库

有时候我们导入的neo4j数据库可能是某个特定账户的,需要通过账户和密码才能访问到这个数据库。对于这种情况,我们先使用帐号通过Cypher Shell登录neo4j后,然后创建一个空的目标库,最后在导入数据库时通过**--overwrite-destination=true**的参数,将创建的空库给覆盖掉。需要注意的是导入数据库的名称和创建的空库的名称要一样。

(1).通过Cypher Shell登录neo4j

进入neo4j数据库bin目录下,执行./cypher-shell 命令后,再输入账号和密码,即可登录neo4j数据库。

bash 复制代码
./cypher-shell

(2).创建目标空库

bash 复制代码
-- 登录后,先切换到system数据库
:use system;

-- 尝试创建数据库
create database myneo4jdb;

-- 查看数据库
show databases;

(3).覆盖目标空库

对于以上步骤2中创建的空数据库,我们再使用数据库导出文件将这个空数据覆盖掉就可以了。

bash 复制代码
neo4j-admin database load --from-path=/var/lib/neo4j/import/ myneo4jdb --overwrite-destination=true
相关推荐
倔强的石头_1 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou641 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1773 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再4 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest4 天前
数据库SQL学习
数据库·sql