Mongo导入导出详解

一、二进制导入导出(推荐)

适用场景:全量备份/恢复,保留索引和元数据

工具:mongodumpmongorestore

1. 导出数据 (mongodump)

bash 复制代码
mongodump --host <hostname> --port <port> \
          --username <username> --password <password> \
          --db <database_name> \
          --collection <collection_name> \
          --out <output_directory>

常用参数:

  • --gzip: 压缩输出
  • --query: 按条件导出数据
  • --authenticationDatabase: 认证数据库

2. 导入数据 (mongorestore)

bash 复制代码
mongorestore --host <hostname> --port <port> \
             --username <username> --password <password> \
             --db <target_database> \
             <input_directory>

常用参数:

  • --drop: 导入前清空集合
  • --gzip: 解压导入
  • --nsInclude: 指定导入的命名空间

二、JSON/CSV 导入导出

适用场景:跨平台数据交换,可读性强

工具:mongoexportmongoimport

1. 导出为 JSON/CSV (mongoexport)

bash 复制代码
mongoexport --host <hostname> --port <port> \
            --username <username> --password <password> \
            --db <database_name> \
            --collection <collection_name> \
            --type json (或 csv) \
            --fields <field1,field2> \
            --out <output_file.json>

常用参数:

  • --query: 按条件导出(使用 JSON 格式)
  • --limit: 限制导出条数
  • --pretty: 格式化输出

2. 导入 JSON/CSV (mongoimport)

bash 复制代码
mongoimport --host <hostname> --port <port> \
            --username <username> --password <password> \
            --db <database_name> \
            --collection <collection_name> \
            --type json (或 csv) \
            --file <input_file.json>

常用参数:

  • --drop: 导入前清空集合
  • --headerline: CSV 文件包含表头
  • --upsert: 使用更新插入模式

三、注意事项

  1. 数据类型兼容性
    JSON 格式可能丢失 MongoDB 特有类型(如 Date, ObjectId),建议优先使用二进制格式。
  2. 索引处理
    mongoexport/import 不会保留索引,需手动重建;mongodump/restore 会保留索引。
  3. 大文件处理
    使用 --gzip 压缩可减少传输体积,处理大型数据时建议分片操作。
  4. 认证与权限
    确保用户对目标数据库有 readWrite 权限,使用 --authenticationDatabase 指定认证库。

四、示例场景

案例1:导出 users 集合到 JSON

bash 复制代码
mongoexport --db mydb --collection users --out users.json

案例2:从 CSV 恢复数据到新集合

bash 复制代码
mongoimport --db mydb --collection new_users --type csv --headerline --file users.csv

案例3:全库备份与恢复

bash 复制代码
# 备份
mongodump --db mydb --out /backup/20231001
# 恢复
mongorestore --db mydb_restored /backup/20231001/mydb
相关推荐
随逸1773 小时前
《Milvus向量数据库从入门到实战,手把手搭建语义检索系统》
数据库
神秘的猪头4 小时前
🚀 React 开发者进阶:RAG 核心——手把手带你玩转 Milvus 向量数据库
数据库·后端·llm
IvorySQL1 天前
PostgreSQL 技术日报 (3月6日)|为什么 Ctrl-C 在 psql 里让人不安?
数据库·postgresql·开源
NineData1 天前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
IvorySQL1 天前
PostgreSQL 技术日报 (3月5日)|规划器控制力升级,内核能力再进阶
数据库·postgresql·开源
数据组小组2 天前
免费数据库管理工具深度横评:NineData 社区版、Bytebase 社区版、Archery,2026 年开发者该选哪个?
数据库·测试·数据库管理工具·数据复制·迁移工具·ninedata社区版·naivicat平替
悟空聊架构2 天前
基于KaiwuDB在游乐场“刷卡+投币”双模消费系统中的落地实践
数据库·后端·架构
IvorySQL2 天前
PostgreSQL 技术日报 (3月4日)|硬核干货 + 内核暗流一网打尽
数据库·postgresql·开源
进击的丸子2 天前
虹软人脸服务器版SDK(Linux/ARM Pro)多线程调用及性能优化
linux·数据库·后端