直播365足球-beat365投注网站-bst365官网

MongoDB简介及应用场景

传统的关系型数据库(如MySQL),在数据操作的“三高”需求以及应对Web2.0的网站需求面前,显得力不从心。而MongoDB可应对“三高”需求。“三

MongoDB简介及应用场景

传统的关系型数据库(如MySQL),在数据操作的“三高”需求以及应对Web2.0的网站需求面前,显得力不从心。而MongoDB可应对“三高”需求。“三高”需求:

(1)High performance - 对数据库高并发读写的需求。

(2)Huge Storage - 对海量数据的高效率存储和访问的需求。

(3)High Scalability && High Availability- 对数据库的高可扩展性和高可用性的需求。 而MongoDB可应对“三高”需求。

什么场景应该用 MongoDB ?

MongoDB 的应用已经渗透到各个领域,比如游戏、物流、电商、内容管理、社交、物联网、视频直播等,以下是几个实际的应用案例。

游戏场景,使用 MongoDB 存储游戏用户信息,用户的装备、积分等直接以内嵌文档的形式存储,方便查询、更新

物流场景,使用 MongoDB 存储订单信息,订单状态在运送过程中会不断更新,以 MongoDB 内嵌数组的形式来存储,一次查询就能将订单所有的变更读取出来。

社交场景,使用 MongoDB 存储存储用户信息,以及用户发表的朋友圈信息,通过地理位置索引实现附近的人、地点等功能

物联网场景,使用 MongoDB 存储所有接入的智能设备信息,以及设备汇报的日志信息,并对这些信息进行多维度的分析

视频直播,使用 MongoDB 存储用户信息、礼物信息等。

这些应用场景中,数据操作方面的共同特点是:

(1)数据量大

(2)写入操作频繁(读写都很频繁)

(3)价值较低的数据,对事务性要求不高 对于这样的数据,我们更适合使用MongoDB来实现数据的存储。

辅助决策

如果你还在为是否应该使用 MongoDB,不如来做几个选择题来辅助决策

(注:以下内容改编自 MongoDB 公司 TJ 同学的某次公开技术分享)。

如果上述有1个 Yes,可以考虑 MongoDB,2个及以上的 Yes,选择MongoDB绝不会后悔。

MongoDB简介

MongoDB是一个开源、高性能、无模式的文档型数据库,当初的设计就是用于简化开发和方便扩展,是NoSQL数据库产品中的一种。是最像关系型数据库(MySQL)的非关系型数据库。 它支持的数据结构非常松散,是一种类似于 JSON 的 格式叫BSON,所以它既可以存储比较复杂的数据类型,又相当的灵活。

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

体系结构

MySQL和MongoDB对比

数据模型

MongoDB的最小存储单位就是文档(document)对象。文档(document)对象对应于关系型数据库的行。数据在MongoDB中以 BSON(Binary-JSON)文档的格式存储在磁盘上。

BSON(Binary Serialized Document Format)是一种类json的一种二进制形式的存储格式,简称Binary JSON。BSON和JSON一样,支持 内嵌的文档对象和数组对象,但是BSON有JSON没有的一些数据类型,如Date和BinData类型。

BSON采用了类似于 C 语言结构体的名称、对表示方法,支持内嵌的文档对象和数组对象,具有轻量性、可遍历性、高效性的三个特点,可以有效描述非结构化数据和结构化数据。这种格式的优点是灵活性高,但它的缺点是空间利用率不是很理想。

Bson中,除了基本的JSON类型:string,integer,boolean,double,null,array和object,mongo还使用了特殊的数据类型。这些类型包括 date,object id,binary data,regular expression 和code。每一个驱动都以特定语言的方式实现了这些类型,查看你的驱动的文档来获取详 细信息。

BSON数据类型参考列表:

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

MongoDB的优点

MongoDB 为需要可靠数据库的公司提供了众多优势。以下是使用 MongoDB 的一些好处:

速度:MongoDB比一般的关系数据库快 100 倍。作为一个面向文档的数据库,MongoDB 通过索引使访问文档变得容易。这有助于快速查询响应,从而节省用户宝贵的时间。

分片:MongoDB 提供的另一个好处是它允许用户存储大量数据。这是通过将数据分发到连接到应用程序的多个服务器来完成的。如果一台服务器无法处理数据的大小,则通过称为自动分片的过程将其共享给另一台服务器。

灵活的数据库:MongoDB 允许用户在单独的文档中拥有不同类型的数据,因为它是一个无模式的数据库。这为其用户提供了高度的灵活性和存储任何类型数据的自由。

水平可扩展性:MongoDB 是一个可水平扩展的数据库,这是它的基本优势之一。它允许用户有效地将大量数据分发到多台机器。

事务可行性:一些 MongoDB 功能包括gridFS 和 Replication。这些功能支持在使用 MongoDB 时提高数据可用性。这确保了应用程序的性能非常高。

缺少模式:MongoDB 是 NoSQL,这意味着它不需要模式。因此,在使用 MongoDB 时无需概述数据库模式。这减少了数据库处理信息所需的时间。因此,您的架构将由您编写的算法定义。

MongoDB 的局限性

尽管 MongoDB 提供了优于其他数据库的显着优势,但它并不完美。它有一些需要改进的限制。以下是 MongoDB 的一些缺点。

不支持连接:与支持连接的理性数据库不同,MongoDB 不支持。虽然可以通过手动编码添加连接功能,但执行速度可能会很慢并影响性能。

高内存使用率:MongoDB 旨在为每个值对存储键名称。它还受到数据冗余的影响,因为它缺少连接功能。这会导致高内存使用率。

有限数据大小:MongoDB 允许的最大文档大小为16MB。这是一个需要纠正的严峻挑战。

有限嵌套:MongoDB 提供有限的嵌套访问,因为用户不能执行超过100 级的文档嵌套。

补充理解

怎么理解MongoDB 允许用户在单独的文档中拥有不同类型的数据,因为它是一个无模式的数据库。这为其用户提供了高度的灵活性和存储任何类型数据的自由?

举个例子说明

当使用MongoDB存储博客平台的数据时,以下是一个可能的示例:

假设我们有一个名为"posts"的集合,用于存储博客文章。每篇文章可以具有不同的字段和结构

1.第一篇文章的文档可能如下所示:

这篇文章有一个标题(title)字段,内容(content)字段,作者(author)字段,标签(tags)字段,日期(date)字段和浏览次数(views)字段。

2.第二篇文章的文档可能如下所示:

这篇文章与第一篇文章不同,它有一个不同的字段结构。它有一个标题(title)字段,内容(content)字段,作者(author)字段,分类(categories)字段,日期(date)字段和点赞数(likes)字段。

通过这个例子,您可以看到MongoDB允许在同一个集合中存储具有不同结构和字段的文档。这使得存储博客文章的集合非常灵活,可以根据每篇文章的特定要求自由定义字段。这种灵活性使得开发人员能够根据应用程序的需求轻松地修改和扩展数据模型。

参考

最佳 7 个真实世界 MongoDB 用例

什么场景应该用 MongoDB ?

← 上一篇: 说说HTTP 常见的状态码有哪些,适用场景?
下一篇: 计算机主板有没有寿命,主板能用几年_主板的使用寿命是多久图文教程 →

相关推荐

3、剑灵冰库在哪

3、剑灵冰库在哪

剑灵白青冰雪村在地图12级后进入祭龙林,任务继续做,争取拿到祭龙林小英雄牌换八卦(18级),武器拿绿明村左上角瘟疫虫的蓝色武器。19级后

CPU执行程序的过程

CPU执行程序的过程

CPU执行程序的过程 目录CPU执行程序的过程前言/基础知识为了更好的分析程序的执行过程,我们还需要了解一下基础的计算机硬件信息在执行指

奇迹mu瑞币武器名称,奇迹武器装备一览表

奇迹mu瑞币武器名称,奇迹武器装备一览表

mu奇迹黎明代言,黎明代言的奇迹游戏 大家好,如果您还对mu奇迹黎明代言不太了解,没有关系,今天就由本站为大家分享mu奇迹黎明代言的知识

鳳(凤)

鳳(凤)

【鳳】字造字法为形聲。从鳥,凡聲。 【鳳】字拼音为fèng, 注音为ㄈㄥˋ, 简体部首为鳥, 简体笔画为14画。 【鳳】字五笔为MDHO, 五笔98版为WGQO,

工程量要算些什么软件 5款工程量计算软件让你轻松搞定项目

工程量要算些什么软件 5款工程量计算软件让你轻松搞定项目

在工程项目中,工程量计算是至关重要的一环。1、广联达,2、鲁班软件,3、品茗,4、CAD软件,5、简道云是五款常用的工程量计算软件,能够

英雄联盟回复私聊方法,使用快捷键可以不切屏

英雄联盟回复私聊方法,使用快捷键可以不切屏

回复好友私聊有很多方法,在英雄联盟中频繁切屏会导致延迟卡顿,所以玩家们可以使用/r的快捷键来帮助我们直接回复好友消息,也能通过/msg+