MongoDB简介

MongoDB是一个开源,高性能,无模式的文档型数据库。

它支持的数据结构非常松散,是一种类似于JSON的格式叫BSON,所以他既可以存储比较复杂的数据类型,又相当的灵活。

MongoDB中的记录是一个文档,它是一个由字段可值对(field:value)组成的数据结构。MongoDB文档类似于JSON对象,
即一个文档认为就是一个对象。字段的数据类型是字符型,它的值除了使用基本的一些类型外,还可以包括其它文档,普通数组和文档数组。

体系结构:

Mysql和MongoDB对比

图mysqlandmongo对比

SQL术语 MongoDB术语 解释说明
database database 数据库
table collection 数据表/集合
row document 数据记录行/文档
column field 数据字段/域
index index 索引
table joins 表连接,MongoDB不支持
嵌入文档 MongoDB通过嵌入式文档来替代多表连接
primary key primary key 主键,MongoDB自动将_id字段设置为主键

数据模型

MongoDB最小存储单位就是文档(document)对象。文档(document)对象对应于关系型数据库的行。
数据在MongoDB中以BSON(Binary-JSON)文档的合适存储在磁盘上。 BSON(Binary Serialized Document Format)是一类json的一种二进制形式的存储格式。简称BinaryJSON。
BSON和JSON一样,支持内嵌的文档对象和数组对象,但是BSON有Data和BinData类型,而JSON没有。 Bson中,除了基本的JSON类型:string,integer,boolean,double,array和obkect,
mongo还使用了特殊的类型:data,Object id,binary data,regular expression 和code
每一个驱动都以特定语言的方式实现这些类型,查看你的驱动的文档来获取详细信息
数据类型 描述 举例
字符串 UTF-8字符串都可表示为字符串类型的数据 {"x":"foobar"}
对象id 对象id是文档的12字节的唯一 ID {"x": Objectid() }
布尔值 true或false {"x":true}+
数组 值的集合或者列表可以表示成数组 {"x":{"a","b","c"}}
32位整数 类型不可用,javascript仅支持64位浮点数,所以32位整数会被自动转换 shell是不支持该类型的,shell中默认会转换成64位浮点数
64位整数 不支持这个类型。shell会使用一个特殊的内嵌文档来显示64位整数 shell是不支持该类型的,shell中默认会转换成64位浮点数
64位浮点数 shell中的数字就是这一种类型 {"x": 3.1415926,"y": 3}
null 表示空值或者未定义的对象 {"x":null}
undefined 文档中也可以使用未定义类型 {"x":undefined}
符号 shell不支持,shell会将数据库中的符号类型的数据自动转换成字符串
正则表达式 文档中可以包含正则表达式,采用javascript的正则表达式语言 {"x": /foobar/i}
代码 文档中还可以包含javascript代码 {"x": function{/* .....*/}}
二进制数据 二进制数据可以由任意的串组成,不过shell中无法使用
最大值/最小值 BSON包括一个特殊类型,表示可能的最大值,
shell中没有这个类型

提示:

shell默认使用64位浮点值。{"x":3.14}或者{"x": 3} 对于整型值,可以使用NumberInt(4字节符号整数)或者BumberLong(8字节符号整数), {"x":NumberInt("3")}{"x":NumberLong("3")}

MongoDB的特点:

  • 高性能

    Mongodb提供高性能的数据持久性。
    对嵌入式数据模型的支持减少了数据库系统上的IO活动。
    索引支持更快的查询,并且可以包含来自 嵌入式文档和数组的键。
    [文本索引解决搜索的需求,TTL索引解决历史数据自动过期的需求,地理位置索引可用于构建各种O2O应用] mmavp1,wiredtiger,mongorocks(rocksdb),in-memory等多种引擎支持满足各种需求
    Gridfs解决文件存储的需求
  • 高可用性

    MongoDB的复制工具称为副本集(replica set),它可以提供自动故障转移和数据冗余。
  • 高扩展性

    MongoDB提供了水平可扩展性作为其核心功能的一部分。
    分片将数据分布在一组集群的机器上。(海量数据存储,服务能力水平扩展)
    from 3.4版本,MongoDB支持片键创建数据区域。在一个平衡的集群中,MongoDB将一个区域索覆盖的读写定向到该区域内的那些片。
  • 丰富的查询支持

    MongoDB支持丰富的查询语言,支持读写操作(CRUD)

MongoDB_02简介的更多相关文章

  1. ASP.NET Core 1.1 简介

    ASP.NET Core 1.1 于2016年11月16日发布.这个版本包括许多伟大的新功能以及许多错误修复和一般的增强.这个版本包含了多个新的中间件组件.针对Windows的WebListener服 ...

  2. MVVM模式和在WPF中的实现(一)MVVM模式简介

    MVVM模式解析和在WPF中的实现(一) MVVM模式简介 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 MVVM模式解析和在 ...

  3. Cassandra简介

    在前面的一篇文章<图形数据库Neo4J简介>中,我们介绍了一种非常流行的图形数据库Neo4J的使用方法.而在本文中,我们将对另外一种类型的NoSQL数据库——Cassandra进行简单地介 ...

  4. REST简介

    一说到REST,我想大家的第一反应就是“啊,就是那种前后台通信方式.”但是在要求详细讲述它所提出的各个约束,以及如何开始搭建REST服务时,却很少有人能够清晰地说出它到底是什么,需要遵守什么样的准则. ...

  5. Microservice架构模式简介

    在2014年,Sam Newman,Martin Fowler在ThoughtWorks的一位同事,出版了一本新书<Building Microservices>.该书描述了如何按照Mic ...

  6. const,static,extern 简介

    const,static,extern 简介 一.const与宏的区别: const简介:之前常用的字符串常量,一般是抽成宏,但是苹果不推荐我们抽成宏,推荐我们使用const常量. 执行时刻:宏是预编 ...

  7. HTTPS简介

    一.简单总结 1.HTTPS概念总结 HTTPS 就是对HTTP进行了TLS或SSL加密. 应用层的HTTP协议通过传输层的TCP协议来传输,HTTPS 在 HTTP和 TCP中间加了一层TLS/SS ...

  8. 【Machine Learning】机器学习及其基础概念简介

    机器学习及其基础概念简介 作者:白宁超 2016年12月23日21:24:51 摘要:随着机器学习和深度学习的热潮,各种图书层出不穷.然而多数是基础理论知识介绍,缺乏实现的深入理解.本系列文章是作者结 ...

  9. Cesium简介以及离线部署运行

    Cesium简介 cesium是国外一个基于JavaScript编写的使用WebGL的地图引擎,一款开源3DGIS的js库.cesium支持3D,2D,2.5D形式的地图展示,可以自行绘制图形,高亮区 ...

随机推荐

  1. JavaWeb项目http请求报错:Error parsing HTTP request header

    详细报错信息如下图: 原因:一一排查后,发现是http的请求中,包含了  “ | ” 竖线特殊符号:而并不是网上说的请求url太长了的原因. 解决方法:把 | 替换为  @

  2. C++ — 后缀表达式转表达式树

    2018-07-21 16:57:26 update 建立表达式树的基本思路:方法类似由下而上建立堆的思想,所以时间复杂度为O(n),这样算法就会变得很简单,只用考虑处理需要入栈的节点和栈中的节点即可 ...

  3. Xftp和Xshell

    Xftp 用于跟云虚拟机文件传输的工具,Xftp官网 Xshell Xftp的兄弟工具,用于执行云虚拟机命令,Xshell官网 两个都是付费工具,各需要几百块钱,当然破解的版本也很多 登陆 这两个的连 ...

  4. 「BJOI2018」求和

    「BJOI2018」求和 传送门 观察到 \(k\) 很小而且模数不会变,所以我们直接预处理 \(k\) 取所有值时树上前缀答案,查询的时候差分一下即可. 参考代码: #include <alg ...

  5. red hat 7、centos7的root密码破译

    一.在开机画面时按"E". 二.找到linux16开头的这段,在段尾添加空格"rd.break"然后按Ctrl+x进入系统紧急救援模式. 三.新的界面出现命令行 ...

  6. 128、Java面向对象之对象的比较

    01.代码如下: package TIANPAN; class Book { private String title; private double price; public Book(Strin ...

  7. elasticsearch 自定义routing

    由于线上elasticsearch集群数据量越来越大,优化已经已经是重中之重. 优化的方式有很多中,网上一大堆,自行百度. 优化方案中有个叫routing的方案是个需要熟悉业务日志才能使用.于是我就研 ...

  8. Python 爬取 北京市政府首都之窗信件列表-[信息展示]

    日期:2020.01.25 博客期:133 星期六 [代码说明,如果要使用此页代码,必须在本博客页面评论区给予说明] //博客总体说明 1.准备工作 2.爬取工作 3.数据处理 4.信息展示(本期博客 ...

  9. php 增删改查范例(2)

    增加页面add.php: <!DOCTYPE html><html lang="en"><head>    <meta charset=& ...

  10. 虚拟机下安装 VMwareTools 实现宿主机和虚拟机的文件共享

    $ mount /dev/sr0 /media/ #点击 虚拟机 安装 VMwareTools 挂载 $ cd /media/ $ cp VMwareTools-10.1.6-5214329.tar. ...