MongoDB 导出导入备份恢复数据实例

2023-05-16

创建测试数据

创建db:testdb,collection:user,插入10条记录

mongo
MongoDB shell version: 3.0.2
connecting to: test
> use testdb
switched to db testdb
> db.user.insert({id:1,name:"用户1"});
WriteResult({ "nInserted" : 1 })
> db.user.insert({id:2,name:"用户2"});
WriteResult({ "nInserted" : 1 })
> db.user.insert({id:3,name:"用户3"});
WriteResult({ "nInserted" : 1 })
> db.user.insert({id:4,name:"用户4"});
WriteResult({ "nInserted" : 1 })
> db.user.insert({id:5,name:"用户5"});
WriteResult({ "nInserted" : 1 })
> db.user.insert({id:6,name:"用户6"});
WriteResult({ "nInserted" : 1 })
> db.user.insert({id:7,name:"用户7"});
WriteResult({ "nInserted" : 1 })
> db.user.insert({id:8,name:"用户8"});
WriteResult({ "nInserted" : 1 })
> db.user.insert({id:9,name:"用户9"});
WriteResult({ "nInserted" : 1 })
> db.user.insert({id:10,name:"用户10"});
WriteResult({ "nInserted" : 1 })
> 
> db.user.find();
{ "_id" : ObjectId("574d7aae8780832e6c4e27b4"), "id" : 1, "name" : "用户1" }
{ "_id" : ObjectId("574d7aaf8780832e6c4e27b5"), "id" : 2, "name" : "用户2" }
{ "_id" : ObjectId("574d7aaf8780832e6c4e27b6"), "id" : 3, "name" : "用户3" }
{ "_id" : ObjectId("574d7aaf8780832e6c4e27b7"), "id" : 4, "name" : "用户4" }
{ "_id" : ObjectId("574d7aaf8780832e6c4e27b8"), "id" : 5, "name" : "用户5" }
{ "_id" : ObjectId("574d7aaf8780832e6c4e27b9"), "id" : 6, "name" : "用户6" }
{ "_id" : ObjectId("574d7aaf8780832e6c4e27ba"), "id" : 7, "name" : "用户7" }
{ "_id" : ObjectId("574d7aaf8780832e6c4e27bb"), "id" : 8, "name" : "用户8" }
{ "_id" : ObjectId("574d7aaf8780832e6c4e27bc"), "id" : 9, "name" : "用户9" }
{ "_id" : ObjectId("574d7ab08780832e6c4e27bd"), "id" : 10, "name" : "用户10" }


数据导出 mongoexport

参数说明:

-d     数据库名
-c     collection名
-o     输出的文件名
--type 输出的格式,默认为json
-f     输出的字段,如果--type为csv,则需要加上 -f "字段名"

更多参数说明可参考 mongoexport –help

例子:导出user所有记录到/tmp/user.json

mongoexport -d testdb -c user -o /tmp/user.json
2016-05-31T20:00:32.257+0800    connected to: localhost
2016-05-31T20:00:32.286+0800    exported 10 records

cat /tmp/user.json
{"_id":{"$oid":"574d7aae8780832e6c4e27b4"},"id":1,"name":"用户1"}
{"_id":{"$oid":"574d7aaf8780832e6c4e27b5"},"id":2,"name":"用户2"}
{"_id":{"$oid":"574d7aaf8780832e6c4e27b6"},"id":3,"name":"用户3"}
{"_id":{"$oid":"574d7aaf8780832e6c4e27b7"},"id":4,"name":"用户4"}
{"_id":{"$oid":"574d7aaf8780832e6c4e27b8"},"id":5,"name":"用户5"}
{"_id":{"$oid":"574d7aaf8780832e6c4e27b9"},"id":6,"name":"用户6"}
{"_id":{"$oid":"574d7aaf8780832e6c4e27ba"},"id":7,"name":"用户7"}
{"_id":{"$oid":"574d7aaf8780832e6c4e27bb"},"id":8,"name":"用户8"}
{"_id":{"$oid":"574d7aaf8780832e6c4e27bc"},"id":9,"name":"用户9"}
{"_id":{"$oid":"574d7ab08780832e6c4e27bd"},"id":10,"name":"用户10"}

例子:导出user所有id到/tmp/user.csv

格式为csv但不指定字段会出错

mongoexport -d testdb -c user --type csv -o /tmp/user.csv
2016-05-31T20:01:05.393+0800    Failed: CSV mode requires a field list

mongoexport -d testdb -c user --type csv -f "id" -o /tmp/user.csv
2016-05-31T20:01:46.510+0800    connected to: localhost
2016-05-31T20:01:46.534+0800    exported 10 records

cat /tmp/user.csv
id
1
2
3
4
5
6
7
8
9
10


数据导入 mongoimport

参数说明:

-d           数据库名
-c           collection名
--type       导入的格式,默认json
-f           导入的字段名
--headerline 如果导入的格式是csv,则可以使用第一行的标题作为导入的字段
--file       要导入的文件

更多参数说明可参考 mongoimport –help

导入前先清空collection user

> db.user.drop();
true
> db.user.find();
> 

例子:把上例导出的user.json导入

mongoimport -d testdb -c user --file /tmp/user.json
2016-05-31T20:10:22.240+0800    connected to: localhost
2016-05-31T20:10:22.287+0800    imported 10 documents

例子:把上例导出的user.csv导入

mongoimport -d testdb -c user --type csv --headerline --file /tmp/user.csv
2016-05-31T20:11:28.975+0800    connected to: localhost
2016-05-31T20:11:29.003+0800    imported 10 documents


数据备份 mongodump

参数说明:

-d 数据库名
-c collection名
-o 备份的文件路径

更多参数说明可参考 mongodump –help

例子:把testdb的user备份到/tmp

mongodump -d testdb -c user -o /tmp
2016-05-31T20:18:25.813+0800    writing testdb.user to /tmp/testdb/user.bson
2016-05-31T20:18:25.818+0800    writing testdb.user metadata to /tmp/testdb/user.metadata.json
2016-05-31T20:18:25.849+0800    done dumping testdb.user


数据恢复 mongorestore

参数说明:

-d 数据库名
-c collection名

更多参数说明可参考 mongorestore –help

导入前先清空collection user

> db.user.drop();
true
> db.user.find();
>

例子:把上例备份的数据恢复

mongorestore -d testdb -c user /tmp/testdb/user.bson 
2016-05-31T20:21:23.050+0800    checking for collection data in /tmp/testdb/user.bson
2016-05-31T20:21:23.084+0800    reading metadata file from /tmp/testdb/user.metadata.json
2016-05-31T20:21:23.088+0800    restoring testdb.user from file /tmp/testdb/user.bson
2016-05-31T20:21:23.153+0800    restoring indexes for collection testdb.user from metadata
2016-05-31T20:21:23.156+0800    finished restoring testdb.user
2016-05-31T20:21:23.156+0800    done
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

MongoDB 导出导入备份恢复数据实例 的相关文章

  • php 字符编码转换类,支持ANSI、Unicode、Unicode big endian、UTF-8、UTF-8+Bom 互相转换

    php 字符编码转换类 xff0c 支持ANSI Unicode Unicode big endian UTF 8 UTF 8 43 Bom 互相转换 四种常见文本文件编码方式 ANSI编码 xff1a 无文件头 文件编码开头标志性字节 A
  • linux ps 查看进程命令

    linux 中ps 命令是Process Status 的缩写 ps命令可以列出系统中当前运行的进程 xff0c 所列出的进程是执行ps命令这个时刻正在运行的进程 如果要动态显示进程信息 xff0c 需要使用top命令 通过ps命令 xff
  • linux 使用rename命令批量重命名文件

    linux 使用rename命令批量重命名文件 命令格式 xff1a Usage rename v n f perlexpr filenames 参数说明 xff1a v 显示文件重命名的细节 n 不执行重命名 xff0c 但会模拟执行重命
  • mysql workbench中PK,NN,UQ,BIN,UN,ZF,AI字段类型标识说明

    使用mysql workbench建表时 xff0c 字段中有PK NN UQ BIN UN ZF AI几个基本字段类型标识 它们分别代表的意思是 xff1a PK xff1a primary key 主键 NN xff1a not nul
  • 电脑连得上Wifi打开网页速度慢,但使用热点却没问题怎么解决

    这是我个人的一个问题解决帖 xff0c 当时电脑出来这个问题用了很多方法都没有解决 xff0c 而宽带和网卡也都是没有任何问题 xff0c 最后是学校里一个大佬跟我分享的一个解决方法 用ipconfig release 和 ipconfig
  • 系统中有两个version的PHP存在,导致phpunit测试出现问题的解决方法

    今天要搭建本机的LAMP 开发环境 xff0c 因系统自带的php版本是5 5 14 xff0c 但开发要使用的是php 5 6 以上 xff0c 因此安装了php 5 6 7 这样导致了系统中有两个版本的php存在 正常开发是没有问题的
  • eclipse 更改编辑器风格方法

    eclipse 更改编辑器风格方法 1 打开eclipse 选择菜单Help gt Install New Software 2 在Work with 中 xff0c 按Add xff0c 然后在Location中填入 xff1a http
  • mongodb 地理位置搜寻

    LBS xff0c 存储每个地点的经纬度坐标 xff0c 搜寻附近的地点 xff0c 建立地理位置索引可提高查询效率 mongodb地理位置索引 xff0c 2d 和2dsphere xff0c 对应平面和球面 1 创建lbs集合存放地点坐
  • php 版本处理类

    php 版本处理类 例如记录app版本 xff0c 或某些版本数据 xff0c 如果使用1 0 0这种版本格式记录入库 xff0c 在需要筛选查询时会比较麻烦 而把版本字符串转为数字保存 xff0c 可以方便版本间的比较和筛选 例如 xff
  • PDO 查询mysql返回字段整型变为String型解决方法

    PDO 查询mysql返回字段整型变为String型解决方法 使用PDO查询mysql数据库时 xff0c 执行prepare execute后 xff0c 返回的字段数据全都变为字符型 例如id在数据库中是Int的 xff0c 查询后返回
  • nginx access.log 忽略favicon.ico访问记录的方法

    favicon ico 文件是浏览器收藏网址时显示的图标 xff0c 当第一次访问页面时 xff0c 浏览器会自动发起请求获取页面的favicon ico文件 当 favicon ico文件不存在时 xff0c 服务器会记录404日志 12
  • php根据地理坐标获取国家、省份、城市,及周边数据类

    功能 xff1a 当App获取到用户的地理坐标时 xff0c 可以根据坐标知道用户当前在那个国家 省份 城市 xff0c 及周边有什么数据 原理 xff1a 基于百度Geocoding API 实现 xff0c 需要先注册百度开发者 xff
  • Mac查看本机IP地址方法

    Mac查看本机IP地址方法 1 使用command 43 shift 43 u 打开实用工具 2 选择 终端 打开 3 输入 ifconfig grep inet grep v 127 0 0 1 显示 inet 开头的那行就是本机的IP地
  • 使用ssh-keygen生成私钥和公钥

    1 使用ssh keygen生成私钥和公钥 命令如下 xff1a ssh span class hljs attribute keygen span span class hljs attribute t span rsa 例子 xff1a
  • 代码简短且隐蔽的后门木马

    本文将介绍一个代码很简短 xff0c 而且很隐蔽的后门木马 xff0c 以便让大家在检测程序时可以避免被挂木马 文件内容如下 xff1a lt php 64 span class hljs variable span 61 span cla
  • H264视频编码原理基础分析

    引言 本文章旨在记录本人学习有关音视频时对H264码流视频编解码原理部分的内容 xff0c 如有不对请留言指出 1 音视频封装格式 我们一般下载或者播放的视频文件常见都是以 xxx mp4 xxx flv xxx mkv等标识结尾 xff0
  • mysql导出查询结果到csv方法

    要将mysql的查询结果导出为csv xff0c 一般会使用php连接mysql执行查询 xff0c 将返回的查询结果使用php生成csv格式再导出 但这样比较麻烦 xff0c 需要服务器安装php才可以实现 直接使用mysql导出csv方
  • MySQL实用工具汇总

    本文收录了mysql相关的实用工具 工具包括 xff1a 性能测试 xff0c 状态分析 xff0c SQL路由 xff0c 及运维开发相关的所有工具 xff0c 并会持续更新 1 工具套件集 percona toolkit oak too
  • php 判断memcache key/value是否存在方法

    1 memcache简介 memcache是一套分布式高速缓存软件 xff0c 用于数据缓存及分布式网站session存储等 使用key 61 gt value方式存储 xff0c 支持数据压缩存储处理及数据过期处理 value只支持str
  • mysql 使用inet_aton和inet_ntoa处理ip地址数据

    本文将介绍如何在数据库中使用合适格式保存ip地址数据 xff0c 并能方便的对ip地址进行比较的方法 1 保存ip地址到数据库 数据库中保存ip地址 xff0c 字段一般会定义为 xff1a span class hljs escape 9

随机推荐

  • git commit 提交注释规范

    本文将介绍使用git commit时的注释规范 xff0c 提高commit内容的可读性及理解 规范说明 xff1a 1 用一空行分隔标题与正文 2 标题使用大写字母 3 标题不超过50个字符 4 标题使用祈使语气 5 标题不要使用句号结尾
  • html5实现摇一摇功能

    原理 xff1a 使用DeviceMotion实现 xff0c 关于DeviceMotion介绍可以查看 https developer mozilla org en US docs Web Reference Events devicem
  • MySql查看与修改auto_increment方法

    本文将介绍如何查看表的auto increment及其修改方法 查看表当前auto increment 表的基本数据是存放在mysql的information schema库的tables表中 xff0c 我们可以使用sql查出 span
  • js遍历获取表格内数据方法

    本文将介绍如何使用js获取表格内某一单元格的内容 xff0c 表格由table tr td等html标记组成 table表示表格 xff0c tr表示行 xff0c td表示行中列 1 一般的表格结构如下 span class hljs t
  • JS生成二维码(兼容各种浏览器及中文)

    本文将介绍如何使用JS生成二维码 xff0c 兼容各种浏览器及手机端 xff0c 支持中文 代码如下 xff1a span class hljs doctype lt DOCTYPE html gt span span class hljs
  • mysql 严格模式 Strict Mode说明

    1 开启与关闭Strict Mode方法 找到mysql安装目录下的my cnf xff08 windows系统则是my ini 文件 在sql mode中加入STRICT TRANS TABLES则表示开启严格模式 xff0c 如没有加入
  • C++产生随机数

    随机数 计算机的随机数都是由伪随机数 xff0c 即是由小M多项式序列生成的 xff0c 其中产生每个小序列都有一个初始值 xff0c 即随机种子 xff08 注意 xff1a 小M多项式序列的周期是65535 xff0c 即每次利用一个随
  • git 误删分支恢复方法

    在使用git的过程中 xff0c 因为人为因素造成分支 xff08 commit 被删除 xff0c 可以使用以下步骤进行恢复 首先用以下步骤创建一个新分支 xff0c 修改一些文件后删除 xff0c 以便进行恢复 1 创建分支 abc g
  • 软件工程师的鄙视链

    最近这几年在世界各地突然吹起了一股全民写程序的风潮 xff0c 但是身为一介靠写程序 xff08 以及在上班时间胡乱上网 xff09 来谋生的 developer xff08 所谓的 developer 就是 软件工程师 的比较潮的说法 x
  • mac使用brew安装软件失败的通用解决方法

    使用mac的brew安装软件 xff0c 有时会出现安装失败 xff0c 或显示安装成功 xff0c 但不能正常使用的情况 例如安装php56 redis扩展 xff0c 显示安装成功 xff0c 重启后查看phpinfo看不到redis扩
  • node.JS md5加密中文与php结果不一致的解决方法

    因项目需要 xff0c 需要node JS与php做接口调用 xff0c 发现node JS对中文使用md5加密与php对中文md5加密的结果不同 PHP span class php span class hljs preprocesso
  • mysql互换表中两列数据方法

    1 创建表及记录用于测试 span class hljs operator span class hljs keyword CREATE span span class hljs keyword TABLE span span class
  • mysql 时间戳格式化函数from_unixtime使用说明

    我们一般使用字段类型int 11 时间戳来保存时间 xff0c 这样方便查询时提高效率 但这样有个缺点 xff0c 显示的时间戳 xff0c 很难知道真实日期时间 mysql提供了一个时间戳格式化函数from unixtime来转换格式 f
  • mysql函数concat与group_concat使用说明

    1 concat 函数 使用方法 xff1a concat str1 str2 返回的结果为连接参数产生的字符串 xff0c 如有任何一个参数为null xff0c 则返回值为null 注意 xff1a 如果所有参数均为非二进制字符串 xf
  • mysql innodb启动失败无法重启的处理方法

    电脑在使用过程中死机 xff0c 重启后发现mysql没有启动成功 xff0c 查看错误日志发现是innodb出现问题导致mysql启动失败 错误日志 mysql server start Starting MySQL ERROR The
  • mac环境使用sed修改文件出错的解决方法

    sed是linux命令 xff0c 用于处理文件内容 xff08 修改 xff0c 替换等 xff09 xff0c mac中都可以使用 xff0c 但发现相同的替换命令在linux可以正常执行 xff0c 在mac则执行失败 出错原因 用s
  • mysql order by rand() 效率优化方法

    从一次查询中随机返回一条数据 xff0c 一般使用mysql的order by rand 方法来实现 例如 从20万用户中随机抽取1个用户 span class hljs header mysql gt select from user o
  • 汇编语言:使用冒泡排序算法将10个数按从小到大顺序排列

    汇编语言 xff1a 冒泡排序算法 题目描述 自定义一组有首地址为data的10个字的数组 xff0c 请利用冒泡排序算法来编写程序 xff0c 使该数组中的数按照从小到大的次序有序化 xff08 注 xff1a 10个字可以自己定义 xf
  • 今天终于弄懂结构体数组与结构体变量的关系

    本人也是学计算机专业的 xff0c 但我是一个技术小白 xff0c 今年大一刚刚入学 xff0c 现在在过寒假 xff0c 因为我的C语言成绩并不太好 xff0c 父母总是为我感到担忧 xff0c 因此 xff0c 我每天都在敲代码 xff
  • MongoDB 导出导入备份恢复数据实例

    创建测试数据 创建db testdb collection user 插入10条记录 mongo MongoDB shell span class hljs property version span span class hljs num