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
相关推荐
草莓熊Lotso2 小时前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·linux·运维·服务器·数据库·c++·mysql
supericeice2 小时前
创邻科技 Galaxybase Graph Intelligence 图智能平台:一站式可视化图数据存储、图计算与图挖掘平台
数据库·科技
heimeiyingwang2 小时前
【架构实战】NewSQL数据库对比(TiDB/CockroachDB)
数据库·架构·tidb
buhuimaren_2 小时前
pg日常维护
数据库·oracle
大虾别跑2 小时前
Oracle迁移
数据库·oracle
Trouvaille ~2 小时前
【MySQL篇】数据库操作:从创建到管理
linux·数据库·mysql·oracle·xshell·ddl
瀚高PG实验室2 小时前
ETL中,分区表子表未及时收集统计信息,导致sql执行耗时很长
数据库·数据仓库·sql·etl·瀚高数据库
LDG_AGI2 小时前
【搜索引擎】Elasticsearch(二):基于function_score的搜索排序
数据库·人工智能·深度学习·elasticsearch·机器学习·搜索引擎·推荐算法
枫叶林FYL3 小时前
【自然语言处理 NLP】7.2.2.4 去偏见技术与公平性优化
数据库
星川水月3 小时前
SQL 开窗函数排序详解
数据库·sql