备份和恢复
数据备份
在 Mongodb 中,使用 mongodump
命令来备份 MongoDB 数据。该命令可以导出所有数据到指定目录中。
mongodump
命令可以通过参数指定导出的数据量级转存的服务器。
mongodump 命令语法如下:
1 | mongodump -h dbhost -d dbname -o dbdirectory |
-h:MongDB 所在服务器地址,例如:127.0.0.1,当然也可以指定端口号:127.0.0.1:27017
-d:需要备份的数据库实例,例如:test
-o:备份的数据存放位置,例如:c:\data\dump,当然该目录需要提前建立,在备份完成后,系统自动在 dump 目录下建立一个 test 目录,这个目录里面存放该数据库实例的备份数据。
mongodump
命令可选参数列表如下所示:
语法 | 描述 | 实例 |
---|---|---|
mongodump –host HOST_NAME –port PORT_NUMBER | 该命令将备份所有 MongoDB 数据 | mongodump –host runoob.com –port 27017 |
mongodump –dbpath DB_PATH –out BACKUP_DIRECTORY | mongodump –dbpath /data/db/ –out /data/backup/ | |
mongodump –collection COLLECTION –db DB_NAME | 该命令将备份指定数据库的集合。 | mongodump –collection mycol –db test |
【示例】备份全量数据
1 | mongodump -h 127.0.0.1 --port 27017 -o test2 |
【示例】备份指定数据库
1 | mongodump -h 127.0.0.1 --port 27017 -d admin -o test3 |
数据恢复
mongodb 使用 mongorestore
命令来恢复备份的数据。
mongorestore
命令语法如下:
1 | mongorestore -h <hostname><:port> -d dbname <path> |
--host <:port>
,-h <:port>
:MongoDB 所在服务器地址,默认为: localhost:27017--db
,-d
:需要恢复的数据库实例,例如:test,当然这个名称也可以和备份时候的不一样,比如 test2--drop
:恢复的时候,先删除当前数据,然后恢复备份的数据。就是说,恢复后,备份后添加修改的数据都会被删除,慎用哦!<path>
:mongorestore 最后的一个参数,设置备份数据所在位置,例如:c:\data\dump\test。你不能同时指定<path>
和--dir
选项,--dir
也可以设置备份目录。--dir
:指定备份的目录。你不能同时指定<path>
和--dir
选项。
【示例】
1 | mongorestore -h 127.0.0.1 --port 27017 -d test --dir test --drop |
导入导出
mongoimport
和 mongoexport
并不能可靠地保存所有的富文本 BSON 数据类型,因为 JSON 仅能代表一种 BSON 支持的子集类型。因此,数据用这些工具导出导入或许会丢失一些精确程度。
导入操作
在 MongoDB 中,使用 mongoimport
来导入数据。 默认情况下,mongoimport
会将数据导入到本地主机端口 27017 上的 MongoDB 实例中。要将数据导入在其他主机或端口上运行的 MongoDB 实例中,请通过包含 --host
和 --port
选项来指定主机名或端口。 使用 --drop
选项删除集合(如果已经存在)。 这样可以确保该集合仅包含您要导入的数据。
语法格式:
1 | mongoimport -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 -c 表名 --type 类型 --headerline --upsert --drop 文件名 |
【示例】导入表数据
1 | mongoimport -h 127.0.0.1 --port 27017 -d test -c book --drop test/book.dat |
【示例】从 json 文件中导入表数据
1 | mongoimport -h 127.0.0.1 --port 27017 -d test -c student --upsert test/student.json |
【示例】从 csv 文件中导入表数据
1 | mongoimport -h 127.0.0.1 --port 27017 -d test -c product --type csv --headerline test/product.csv |
【示例】导入部分表字段数据
1 | mongoimport -h 127.0.0.1 --port 27017 -d test -c product --type json --upsertFields name,price test/product.json |
导出操作
语法格式:
1 | 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,在这里有共同点
【示例】导出整张表
1 | mongoexport -h 127.0.0.1 --port 27017 -d test -c product -o test/product.dat |
【示例】导出表到 json 文件
1 | mongoexport -h 127.0.0.1 --port 27017 -d test -c product --type json -o test/product.json |
【示例】导出表中部分字段到 csv 文件
1 | mongoexport -h 127.0.0.1 --port 27017 -d test -c product --type csv -f name,price -o test/product.csv |