MongoDB使用mongoexport和mongoimport命令,批量导出和导入JSON数据到同一张表的实例
需求是这样的:需要修改数据库中某个表的所有数据,所以,要全部导出,然后修改,修改完之后,再把修改后的数据给再导入到mongo去。
具体如下:
备份,导出一张表为json文件
具体命令:
mongoexport --host localhost --port 27017 --username ezsonaruser --password 123456 --collection host_locations --db ezsonar_25 --out /root/host_locations.json
解释:
--host后的localhost:要导出数据库 ip --port后的27017:要导出的实例节点端口号 --username后的ezsonaruser:数据库用户名 --password后的123456:数据库用户密码 --collection后的widgets-test:要导出的表名 --db后的ezsonar_25:要导出的表所在数据库名 --out后的/root/host_locations.json:要导出的文件路径(默认为当前文件夹)导出来后的文件,打开的样子是酱紫的。
然后,你就可以在编辑器里面修改啦。修改完之后,再保存。保存之后就可以再导入到数据库啦。
导入,批量插入json数据到一张表去
具体命令:
mongoimport --host localhost --port 27017 --username ezsonaruser --password 123456 --collection host_locations_test --db ezsonar_25 --file /root/shaql/host_locations.json
解释:
-- host后的localhost:要导入的数据库 ip --port后的27017:要导入的实例节点端口号 --username后的ezsonaruser:数据库用户名 --password后的123456:数据库用户密码 --collection后的host_locations_test:要导入的表名 --db后的ezsonar_25:要导入的表所在数据库名 --file后的/root/shaql/host_locations.json:要导入的源文件路径(默认为当前文件夹)需要注意的地方:
1,不需要进入mongo命令行之后,就可以直接使用上面的2个导入导出命令。
2,导入导出的json文件,你不要随意换行,导出来的就是一行一条数据,你就原封不动的给修改完直接保存,不要换行。不要使用txt这么low的编辑器啦,换个高级点的编辑器吧。
最后,附上这个命令的help说明图
mongoimport 导入的help信息展示如下
mongoexport 导出的help信息展示如下
另:
#导出类型为json,数据库:mapdb,集合:bike 字段:bikeId,lat,lng,current_time,source ,条件为source字段为ofo第一条数据mongoexport --port 27030 -u sa -p Expressin@0618 -d mapdb -c bike -f bikeId,lat,lng,current_time,source --type=json -o bike.csv --query='{"source":"ofo"}' --limit=1#导出类型为csv,数据库:mapdb,集合:bike 字段:bikeId,lat,lng,current_time,source ,条件为source字段为ofo第一条数据mongoexport --port 27030 -u sa -p Expressin@0618 -d mapdb -c bike -f bikeId,lat,lng,current_time,source --type=csv -o bike.csv --query='{"source":"ofo"}' --limit=1
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对亿速云的支持。如果你想了解更多相关内容请查看下面相关链接
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。