Mongodb中的mongoexport工具可以把一个collection导出成JSON格式或CSV格式的文件。可以通过参数指定导出的数据项,也可以根据指定的条件导出数据。
该命令的参数如下:
参数 |
参数说明 |
-h |
指明数据库宿主机的IP |
-u |
指明数据库的用户名 |
-p |
指明数据库的密码 |
-d |
指明数据库的名字 |
-c |
指明collection的名字 |
-f |
指明要导出那些列 |
-o |
指明到要导出的文件名 |
-q |
指明导出数据的过滤条件 |
--type |
指定文件类型 |
--authenticationDatabase |
验证数据的名称 |
mongoexport备份实践
备份app库下的vast集合
注:备份文件的名字可以自定义,默认导出了JSON格式的数据。
导出CSV格式的数据
Mongodb中的mongoimport工具可以把一个特定格式文件中的内容导入到指定的collection中。该工具可以导入JSON格式数据,也可以导入CSV格式数据。
该命令的参数如下:
参数 |
参数说明 |
-h |
指明数据库宿主机的IP |
-u |
指明数据库的用户名 |
-p |
指明数据库的密码 |
-d |
指明数据库的名字 |
-c |
指明collection的名字 |
-f |
指明要导出那些列 |
-o |
指明到要导出的文件名 |
-q |
指明导出数据的过滤条件 |
--drop |
插入之前先删除原有的 |
--headerline |
指明第一行是列名,不需要导入。 |
-j |
同时运行的插入操作数(默认为1),并行 |
--authenticationDatabase |
验证数据的名称 |
mongoimport恢复实践
将之前恢复的数据导入
将之前恢复的CSV格式数据导入
【实验】mysql数据迁移至mongodb数据库
将mysql数据库中的mysql下的user表导出。
into outfile '/tmp/user.csv'
fields terminated by ','
optionally enclosed by '"'
escaped by '"'
lines terminated by '\r\n';
命令说明:
fields terminated by ',' ------字段间以,号分隔
optionally enclosed by '"' ------字段用"号括起
escaped by '"' ------字段中使用的转义符为"
lines terminated by '\r\n'; ------行以\r\n结束
查看导出内容
"root","localhost",""
"root","db02",""
"root","127.0.0.1",""
"root","::1",""
"","localhost",""
"","db02",""
"repl","10.0.0.%","*23AE809DDACAF96AF0FD78ED04B6A265E05AA257"
"mha","10.0.0.%","*F4C9AC49A736981AE2739FC2F4A1FD92B4F07929"
在mongodb中导入数据
查看导入的内容
MongoDB shell version: 3.2.8
connecting to: 127.0.0.1:27017/test
> use app
switched to db app
> db.user.find()
{ "_id" : ObjectId("5a53206b3b42ae4683180009"), "user" : "root\tlocalhost" }
{ "_id" : ObjectId("5a53206b3b42ae468318000a"), "user" : "root\tdb02" }
{ "_id" : ObjectId("5a53206b3b42ae468318000b"), "user" : "root\t127.0.0.1" }
{ "_id" : ObjectId("5a53206b3b42ae468318000c"), "user" : "root\t::1" }
{ "_id" : ObjectId("5a53206b3b42ae468318000d"), "user" : "localhost" }
{ "_id" : ObjectId("5a53206b3b42ae468318000e"), "user" : "db02" }
{ "_id" : ObjectId("5a53206b3b42ae468318000f"), "user" : "repl\t10.0.0.%\t*23AE809DDACAF96AF0FD78ED04B6A265E05AA257" }
{ "_id" : ObjectId("5a53206b3b42ae4683180010"), "user" : "mha\t10.0.0.%\t*F4C9AC49A736981AE2739FC2F4A1FD92B4F07929" }
到此数据迁移完成。
1 mongoexport/mongoimport导入/导出的是JSON格式,而mongodump/mongorestore导入/导出的是BSON格式。
2 JSON可读性强但体积较大,BSON则是二进制文件,体积小但对人类几乎没有可读性。
在一些mongodb版本之间,BSON格式可能会随版本不同而有所不同,所以不同版本之间用mongodump/mongorestore可能不会成功,具体要看版本之间的兼容性。当无法使用BSON进行跨版本的数据迁移的时候,使用JSON格式即mongoexport/mongoimport是一个可选项。跨版本的3 3 mongodump/mongorestore并不推荐,实在要做请先检查文档看两个版本是否兼容(大部分时候是的)。
4 JSON虽然具有较好的跨版本通用性,但其只保留了数据部分,不保留索引,账户等其他基础信息。使用时应该注意