mongo备份还原导出导入

mongodb数据库备份和还原是针对库的,有mongodump和mongorestore;导入导出是针对表的,有mongoexport和mongoimport。

一、mongodump备份数据库

格式

mongodump -h 主机地址(ip) –port 端口 -u 用户名 -p 密码 -d 数据库 -o 输出路径

导出所有数据库

mongodump -h 10.11.123.121 -u admin -p admin -o ./databak

导出指定数据库

mongodump -h 10.11.123.121 -u admin -p admin -d users -o ./databak

mongorestore还原数据库

格式

mongorestore -h 主机地址(ip) –port 端口 -u 用户名 -p 密码 -d 数据库 –drop 文件恢复路径
–drop的意思是,先删除所有的记录,然后恢复。

恢复所有数据库道mongodb中

mongorestore -h 10.11.123.121 -u admin -p admin ./datare

恢复指定数据库

mongorestore -h 10.11.123.121 -u admin -p admin -d users ./datare/users

mongoexport导出表,或者表中部分字段

常用命令格式

mongoexport -h IP –port 端口 -u 用户名 -p 密码 -d 数据库 -c 表名 -f 字段 -q 条件导出 –csv -o 文件名
上面的参数好理解,重点说一下:
-f 导出指字段,以字号分割,-f name,email,age导出name,email,age这三个字段
-q 可以根查询条件导出,-q ‘{ “uid” : “100” }’ 导出uid为100的数据
–csv 表示导出的文件格式为csv的,这个比较有用,因为大部分的关系型数据库都是支持csv,在这里有共同点

导出整张表

mongoexport -h 10.11.123.121 -u admin -p admin -d admin -c users -o ./users.dat

导出表中部分字段

mongoexport -h 10.11.123.121 -u admin -p admin -d admin -c users –csv -f uid,name,sex -o admin/users.csv

根据条件敢出数据

mongoexport-h 10.11.123.121 -u admin -p admin -d admin -c users -q ‘{uid:{$gt:1}}’ -o admin/users.json

mongoimport导入表,或者表中部分字段

1,常用命令格式

1.1,还原整表导出的非csv文件

mongoimport -h IP –port 端口 -u 用户名 -p 密码 -d 数据库 -c 表名 –upsert –drop 文件名
重点说一下–upsert,其他参数上面的命令已有提到,–upsert 插入或者更新现有数据

1.2,还原部分字段的导出文件

mongoimport -h IP –port 端口 -u 用户名 -p 密码 -d 数据库 -c 表名 –upsertFields 字段 –drop 文件名
–upsertFields根–upsert一样

1.3,还原导出的csv文件

mongoimport -h IP –port 端口 -u 用户名 -p 密码 -d 数据库 -c 表名 –type 类型 –headerline –upsert –drop 文件名
上面三种情况,还可以有其他排列组合的。

参考jb51