由于一直以来用微软可视化图形界面习惯了,而MongoDB是命令式操作,而用系统自带CMD操作不方便,

这里介绍一款CMD的替代品,大小100多M。

Cmder工具下载  https://github.com/cmderdev/cmder/releases

接下来操作全部用Cmder工具来执行指令操作演示

一.Collection集合导出与导入工具介绍:

NoSQL中Collection集合对应SQL的的关系相当于表的概念,即对表的导出与导入。

导出集合数据工具 mongoexport.exe

导出集合数据工具 mongoimport.exe

二.准备阶段

1.启动 :Cmder.exe (没安装的话,用CMD一样可以)

2.输入:D:    进行MongoDB安装盘

3.输入:cd D:\Program Files\MongoDB\Server\4.0\bin  进入MongoDB安装目录

三.Collection集合导出--Json格式

mongoexport -d pcbdb -c ppeflow -o "e:\db\ppeflow.json"

参数说明:

-d pcbdb                               数据库名

-c ppeflow                            集合名(相当SQL中的表名)

-o "e:\db\ppeflow.json"         输出路径

--typeo json                         默认json输出,当然加入此参数入

四.Collection集合导出--CSV格式

 mongoexport -d pcbdb -c ppeflow --type csv -f "_id,techname,orderid" -o "e:\db\ppeflow.csv"

参数说明:

-d pcbdb                               数据库名

-c ppeflow                            集合名(相当SQL中的表名)

--type csv                           输出格式(注意type前面有2个-)

-f "_id,techname,orderid"     输出字段名(字段与字段之间用,分隔)

-o "e:\db\ppeflow.csv"         输出路径

五.Collection集合导入--Json格式

 mongoimport.exe -d pcbdb -c ppeflow1 --file "e:\db\ppeflow.json"

参数说明:

-d pcbdb                               数据库名

-c ppeflow1                           集合名(当不存在时,自动创建)

-o "e:\db\ppeflow.json"         导入Json路径

--typeo json                         默认json输入格式,当然加入此参数入

六.Collection集合导入--CSV格式

mongoimport -d pcbdb -c ppeflow2 --type csv -f "_id,techname,orderid" --file "e:\db\ppeflow.csv"

参数说明:

-d pcbdb                               数据库名

-c ppeflow2                           集合名(相当SQL中的表名)

--type csv                             输出格式(注意type前面有2个-)

-f "_id,techname,orderid"      输入字段名(字段与字段之间用,分隔)

--file "e:\db\ppeflow.csv"        读取CSV路径(注意file前面有2个-)

-headerline               除去首行的字段行(此例子没加此参数,原因报错,未找到解决方法)

七.关键参数说明
h,--host :代表远程连接的数据库地址,默认连接本地Mongo数据库;
--port:代表远程连接的数据库的端口,默认连接的远程端口27017;
-u,--username:代表连接远程数据库的账号,如果设置数据库的认证,需要指定用户账号;
-p,--password:代表连接数据库的账号对应的密码;
-d,--db:代表连接的数据库;
-c,--collection:代表连接数据库中的集合;
-f, --fields:代表导入集合中的字段;
--type:代表导入的文件类型,包括csv和json,tsv文件,默认json格式;
--file:导入的文件名称
--headerline:导入csv文件时,指明第一行是列名,不需要导入;

八.凝问解答

1.导出的json与CSV是什么文本编码类型是什么格式?

导出的文本编码类型是(encoding)UTF8.

2.用Excel打开CSV是乱码,怎么解决呢?

方法1:用NotePad打开,然后点击菜单【编码】->【转为ANSI编码】,再用Excel打开即可。

方法2:用Excel引用文本的方式加转换,参考https://jingyan.baidu.com/article/48a4205705c098a925250455.html

3.导入CSV到MongoDB去掉首行的字段行?

按官方文档:在导入CSV参数中加入-headerline 即可

mongoimport -d pcbdb -c ppeflow2 --type csv -headerline -f "_id,techname,orderid" --file "e:\db\ppeflow.csv"

但实际在笔者实测中,目前没解决.报如下错误,

4.MongoDB导出CSV可以指定字段导出,那么输出Json文件是否能指定字段导出?

不能,导出的Json文件是整个集成中所有字段.

5.MongoDB导出CSV还是Json格式,如何选择?

通过以下对比,请自行选择.

大小对比: CSV占用字节数少        优势

JSON占用字节数多

深层次结构对比:CSV如果对于大于2层嵌套结构树节构查看不明确。          优势

JSON深层次结构用Json树结构查看器对结构定义清晰,

低层次结构对比:CSV如果对于<=2层嵌套结构树节构查看定义清晰,         平局

JSON低层次结构用Json树结构查看器对结构定义清晰,   平局

字段对比:CSV可选字段输出,      优势

JSON全部字段输出

反序化列:CSV不支持

JSON支持                      优势

6.MongoDB导入CSV是否指定字段输入?

不行,导入CSV并不可以指定字段导入,比如CSV中有3个字段,导入到MongoDB中不能只导入指定的2个字段

而这里的指定字段名,是CSV文件中每个字段指定一个字段名,导入到MongoDB中,

如果CSV有3个字段,而导入的字段名只有2个,那CSV中第3个字段由MongoDB默认fled3字段

(最好CSV有多少个字段,导入的字段名就有多少个,保持字段名数量与字段数量匹配,并且顺序一致)

7.MongoDB导出的Json后,然后再导入,导不进去?

由于导出JSON会将主键_id 即OjbectId,一起输出来的,如果再导入数据库中的的话,肯定会出现主键冲突

  最佳解决方法:导入到另外一个集合,然后再通过2个集成的唯一主键对比,再进行突处理---冲突不替换,还是冲突替换)   

后续对MongoDB的探索学习,主要是基于SQL已有的功能,在MongoDB也应该有的功能进行相应的实现,

后续更新内容:NoSQL与SQL 增删改查的语句区别,主键索引,主从库复制,备份还原,请求数据与性能监控,Log日志,大尺寸文件GridFS.

PCB MongoDB 数据库 Collection集合导出与导入的更多相关文章

  1. MongoDB数据库、集合、文档的操作

    MongoDB系列第一课:MongDB简介 MongoDB系列第二课:MongDB环境搭建 MongoDB系列第三课:MongDB用户管理 MongoDB系列第四课:MongoDB数据库.集合.文档的 ...

  2. PCB MongoDB数据库 备份与还原

    一. MongoDB数据库 备份与还原工具介绍: 数据备份工具  mongodump.exe 数据还原工具   mongorestore.exe 二. MongoDB数据库备份 mongodump - ...

  3. python实践——批量统计mongodb数据库的集合大小

    #!/usr/bin/env python import os,sys list = [] for i in range(3,50): l = os.popen("/bin/echo 'sh ...

  4. Mysql数据库(表)的导出和导入小结

    Why? 有人因为想看导出的开房记录库文件,然后学会了Mysql数据库文件的导入操作~: 有人因为工作原因,要用到数据库的备份与导入,然后应需学会了骚操作~: 我因为~~emmm 想看某个导出的库文件 ...

  5. MongoDB数据库和集合的基本操作

    非关系型数据库 命令区分大小写:命令结束符为回车(与MySQL不同之处) mongodb配置 sudo service mongodb start mongo mongodb基本概念 集合对应于关系型 ...

  6. windows下 Mysql 8.0.x 数据库简单的导出和导入!!!

    1.首先需要进入到mysql安装目录下的bin目录,执行cmd进入命令窗口. 2.导出(导出某个数据库,也可以针对某张表导出)2.1导出数据结构以及数据的命令: mysqldump -u root - ...

  7. Mongodb Capped Collection集合

    MongoDB 固定集合(Capped Collections)是性能出色且有着固定大小的集合,对于大小固定,我们可以想象其就像一个环形队列,当集合空间用完后,再插入的元素就会覆盖最初始的头部的元素! ...

  8. MongoDB数据库和集合的状态信息

    查看数据库统计信息:db.stats()  > use testswitched to db test> db.stats(){        "db" : " ...

  9. MongoDB 数据库、集合创建删除与文档插入

    本文章主要介绍mongodb的基本命令,前提条件,你的本地已经安装了mongo. 一.基本命令使用(主要是创建,增删改.) 0.mongoDb统计信息 获得关于MongoDB的服务器统计,需要在Mon ...

随机推荐

  1. day13-迭代器、三元表达式、列表推导式、字典生成式、生成器与递归

    目录 迭代器 可迭代对象 迭代器对象 for循环原理 三元表达式(三目表达式) 列表推导式 字典生成式 zip()方法 生成器 生成器表达式 递归 递归的两个阶段 迭代器 迭代器即迭代的工具,迭代是一 ...

  2. Mock随机生成数据模拟后台接口

    <html> <head> <title>测试</title> <script src="http://code.jquery.com/ ...

  3. Linux 下phpstudy的安装使用补充说明

    (1)使用方法 在终端中使用sudo 或者 使用管理员账号运行 phpstudy start 开启 (2)命令列表: phpstudy start | stop | restart        开启 ...

  4. nodejs 文件操作模块 fs

    const fs=require("fs"); //文件操作 //创建目录 ./ 代表当前目录 ../ 代表上级目录fs.mkdir('./test',function(err){ ...

  5. JSON,对象..的数据格式

    [此案例为自动产生的随机数] 对象: {a1:180,a2:721, a3:574} 序列化传值:将对象转化为Json字符串 public ActionResult Val2() { Random r ...

  6. Jenkins+Ant+Jmeter自动化集成测试实例

    通过学习Jmeter自动化测试,接触到了Ant命令和其构建文件build.xml文件的编写,与此同时,通过将测试项目集成在jenkins上,进一步学习了jenkins的一些环境配置知识.以下是自己的初 ...

  7. 爬虫文件存储:txt文档,json文件,csv文件

    5.1 文件存储 文件存储形式可以是多种多样的,比如可以保存成 TXT 纯文本形式,也可以保存为 Json 格式.CSV 格式等,本节我们来了解下文本文件的存储方式. 5.1.1 TXT文本存储 将数 ...

  8. MySQL之视图、触发器、存储过程、函数、事务、数据库锁

    一.视图 视图:是一个虚拟表,其内容由查询定义.同真实的表一样,视图包含一系列带有名称的列和行数据. 视图的特点: 1.视图的列可以来自不同的表,是表的抽象和逻辑意义上建立的新关系: 2.视图是由基本 ...

  9. 第五节:numpy之数组维度处理

  10. 6.3.1 使用 pickle 模块读写二进制文件

    Python 标准库 pickle 提供的 dump() 方法 用于将数据进行序列化并写入文件(dump() 方法的protocol 参数为True 时可以实现压缩的效果),而load() 用于读取二 ...