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
相关推荐
卓码软件测评2 小时前
CMA/CNAS软件测评机构:【Gatling数据库性能关联测试JDBC连接和SQL执行时间监控】
数据库·sql·测试工具·性能优化·测试用例
lixora2 小时前
备份指定oracle block 防止误操作
数据库
凯子坚持 c2 小时前
Redis 数据库的服务器部署与 MCP 智能化交互深度实践指南
服务器·数据库·redis
DBA小马哥2 小时前
Oracle迁移金仓全攻略:工业IOT场景下的易用性与安全保障
数据库·物联网·安全·oracle
‘胶己人’2 小时前
redis分布式锁
数据库·redis·分布式
初恋叫萱萱2 小时前
基于CodeRider-Kilo和MySQL开发一款书店管理系统
数据库·mysql·产品运营
Elastic 中国社区官方博客2 小时前
通过 Elasticsearch 中的 function score query 按利润和受欢迎程度提升电商搜索效果
大数据·数据库·elasticsearch·搜索引擎·全文检索
qq_366336372 小时前
mysql-5.7.38-winx64.zip 启动教程(免安装版)
数据库·mysql·adb
不穿格子的程序员2 小时前
Redis篇5——Redis深度剖析:系统的“隐形杀手”——热Key与大Key问题
数据库·redis·缓存·热key·大key