mongodb导入导出

本文介绍使用mongoexportmongoimport命令备份和恢复数据。

1. 使用mongoexport命令备份数据库

相关命令参数:

$ mongoexport --help
Export MongoDB data to CSV, TSV or JSON files.

options:
  -h [ --host ] arg         mongo host to connect to ( <set name>/s1,s2 for
  -u [ --username ] arg     username
  -p [ --password ] arg     password
  -d [ --db ] arg           database to use
  -c [ --collection ] arg   collection to use (some commands)
  -q [ --query ] arg        query filter, as a JSON string
  -o [ --out ] arg          output file; if not specified, stdout is used

1.1 导出所有文档所有字段到文件domain-bk.json文件

$ mongoexport -d webmitta -c domain -o domain-bk.json
connected to: 127.0.0.1
exported 10951 records

1.2 导出所有哦文档的domainworth字段

$ mongoexport -d webmitta -c domain -f "domain,worth" -o domain-bk.json
connected to: 127.0.0.1
exported 10951 records

1.3 通过条件导出文档,下面例子导出worth > 100000的文档

$mongoexport -d webmitta -c domain -f "domain,worth" -q '{worth:{$gt:100000}}' -o domain-bk.json
connected to: 127.0.0.1
exported 10903 records

1.4 使用用户名和密码导出远程服务器的文档

$ mongoexport -h id.mongolab.com:47307 -d heroku_app -c domain -u username123 -p password123 -o domain-bk.json
connected to: id.mongolab.com:47307
exported 10951 records

注意:导出的文档都是json格式

2. 使用mongoimport命令恢复数据库

相关命令参数:

$ mongoimport --help
connected to: 127.0.0.1
no collection specified!
Import CSV, TSV or JSON data into MongoDB.

options:
  -h [ --host ] arg       mongo host to connect to ( <set name>/s1,s2 for sets)
  -u [ --username ] arg   username
  -p [ --password ] arg   password
  -d [ --db ] arg         database to use
  -c [ --collection ] arg collection to use (some commands)
  -f [ --fields ] arg     comma separated list of field names e.g. -f name,age
  --file arg              file to import from; if not specified stdin is used
  --drop                  drop collection first
  --upsert                insert or update objects that already exist

2.1 从domain-bk.json导入文档,导入的数据库名为webmitta2,集合名为domain2。不存在的数据库或集合会被自动创建。

$ mongoimport -d webmitta2 -c domain2 --file domain-bk.json
connected to: 127.0.0.1
Wed Apr 10 13:26:12 imported 10903 objects

2.2 导入文档,无则插入,有则更新(根据_id

$ mongoimport -d webmitta2 -c domain2 --file domain-bk.json --upsert
connected to: 127.0.0.1
Wed Apr 10 13:26:12 imported 10903 objects

2.3 使用用户名和密码连接远程服务器,并从本地文件domain-bk.json导入文档

$ mongoimport -h id.mongolab.com:47307 -d heroku_app -c domain -u username123 -p password123 --file domain-bk.json
connected to: id.mongolab.com:47307
Wed Apr 10 13:26:12 imported 10903 objects
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • mongo/bin目录下的/mongoexport工具可以把一个collection导出成JSON格式或CSV格式...
    潦倒神仙阅读 791评论 0 0
  • 有时候我们需要对数据库中的部分数据或全部数据进行备份,这就需要对数据进行导入和导出: 执行如下命令,将nodebb...
    恐怕是小珠桃子阅读 255评论 0 1
  • 导入(import) 概念 把一个JSON格式或者CSV格式的文件导入为mongodb的collection。 语...
    real_ting阅读 3,176评论 1 2
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,841评论 18 139
  • 导入数据 例如 注意 JSON文件内保存的对象以行为单位,一行一条的记录数据。 导出数据 数据备份 数据恢复 权限配置
    JunChow520阅读 362评论 0 0