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. 02-06Android学习进度报告六

    今天学习了关于Android开发中常用的两个知识,即对话框和悬浮框. 首先我学习了对话框的基本使用流程 Step 1:创建AlertDialog.Builder对象: Step 2:调用setIcon ...

  2. 第1节 Scala基础语法:13、list集合的定义和操作;16、set集合;17、map集合

    list.+:5 , list.::5: 在list集合头部添加单个元素5 : li1.:+(5):在list集合尾部添加单个元素5: li1++li2,li1:::li2:在li1集合尾部添加il2 ...

  3. mkvirtualenv: 未找到命令的解决方法

    1.升级python包管理工具pip pip install --upgrade pip 备注:当你想升级一个包的时候 `pip install --upgrade 包名` 2.python虚拟环境安 ...

  4. uniGUI 应用程序体系结构(11)

    下图表示 uniGUI 服务器的内部结构. 每个 uniGUI 服务器都有一个ServerModule的副本, 每台服务器创建一次, 同时根据用户活动动态创建和销毁多个Session. uniGUI ...

  5. Codeforces 1196D2 RGB Substring (Hard version) 题解

    题面 \(q\) 个询问,每个询问给出一个字符串 \(s\),要你在 \(s\) 中用最小替换得到无穷字符串 RGBRGBRGB... 的长度为定值 \(k\) 的子串. 题解 一眼看过去可能是编辑距 ...

  6. importlib 与__import__的区别

    importlib 与__import__的区别 importlib import importlib name = "lib.test" # lib.test指的是lib路劲下的 ...

  7. Hadoop操作经验

    系统日志文件写入到MySQL中,NoSQL中一般存储独立的关联性不大的非业务数据. 单个NameNode也可以恢复,从SecondaryNameNode恢复:两个NameNode是可以做负载均衡:更高 ...

  8. Linux用户和用户组管理命令

    一.用户管理命令 1.useradd   创建用户或更新默认新用户的信息 使用方法  useradd [options] 用户名 选项: useradd -u           指定UID具体数值, ...

  9. Java-android使用GridView布局的电子相册&服务器获取图片

    转  http://www.tuicool.com/articles/B7JNv2 电子相册的思路: 1.先是考虑布局,我用的是GridView布局 2.GridView中又该怎么显示图片,其实我的这 ...

  10. 六、ibatis1.2.8查询性能优化,实现百万数据zip导出

    经测试发现将查询的结果100万数据(池子中共有大概14亿的数据)写入Excle文件并进行压缩导出zip文件最耗时的地方竟然在查询,因此本篇文章主要是针对如何在spring+ibatis1.2.8中优化 ...