【学习笔记】什么是MongoDB

文章目录

MongoDB 简介

学习一个东西就跟认识一个人一样,下面有情MongoDB来做个自我介绍

大家好,俺是MongoDB,是一个开源高性能无模式的文档型 数据库,当初的设计俺就是用于简化开发方便扩展

俺是NoSQL数据库产品中的一种,是最像关系型数据库(MySQL)的非关系型数据库。

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

俺的记录是一个文档,它是一个由字段值对(field:value)组成的数据结构。

俺的文档类似于JSON对象,即一个文档认为就是一个对象。字段的数据类型是字符型,俺的值除了使用基本的一些类型外,还可以包括其他文档、普通数组和文档数组。

体系结构

听完MongoDB的自我介绍,我稍微对他有了一定的了解。为了更加方便我们的理解,有请出我们的老成员Mysql

Mysql和MongoDB的对比:

Mysql中有多个数据库,数据库中包含多个数据表,数据表中包含多个行数据。

而MongoDB中同样有多个数据库,但是不同的是,数据库中包含的是集合 ,集合中包含多个文档

我们知道mysql中有字段这一概念,MongoDB与之不同的是这一概念。

区别最大的一点莫过于表连接了,mysql中支持table joins来实现表连接,MongoDB 没有像关系型数据库那样直接的表连接概念。

MongoDB是通过嵌入式文档来代替多表连接。

数据模型

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

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

MongoDB 的特点

那么讲了这么多了,MongoDB有什么特点吗?

MongoDB主要有如下特点:

  1. 高性能 :
    MongoDB提供高性能的数据持久性。特别是对嵌入式数据模型的支持减少了数据库系统上的I/O活动。索引支持更快的查询,并且可以包含来自嵌入式文档和数组的键,(文本索引解决搜索的需求、TTL索引解决历史数据自动过期的需求、地理位置索引可用于构建各种 020 应用)mmapv1、wiredtiger、mongorocks(rocksdb)、in·memory等多引擎支持满足各种场景需求Gridfs解决文件存储的需求。
  2. 高可用性 :
    MongoDB的复制工具称为副本集(replicaset),它可提供自动故障转移和数据冗余。
  3. 高扩展性 :
    MongoDB提供了水平可扩展性作为其核心功能的一部分。分片将数据分布在一组集群的机器上。(海量数据存储,服务能力水平扩展)从3.4开始,MongoDB支持基于片键创建数据区域。在一个平衡的集群中,MongoDB将一个区域所覆盖的读写只定向到该区域内的那些片。
  4. 丰富的查询支持 :
    MongoDB支持丰富的查询语言,支持读和写操作(CRUD),比如数据聚合、文本搜索和地理空间查询等。
  5. 其他特点:如无模式(动态模式)、灵活的文档模型
相关推荐
_饭团28 分钟前
字符串函数全解析:12 种核心函数的使用与底层模拟实现
c语言·开发语言·学习·考研·面试·蓝桥杯
Larry_Yanan29 分钟前
Qt网络开发之基于 QWebEngine 实现简易内嵌浏览器
linux·开发语言·网络·c++·笔记·qt·学习
芯跳加速36 分钟前
AI 视频自动化学习日记 · 第三天
人工智能·学习·ai·自动化·音视频
爬山算法1 小时前
MongoDB(50)副本集中的角色有哪些?
数据库·mongodb
小陈phd1 小时前
多模态大模型学习笔记(二十一)—— 基于 Scaling Law方法 的大模型训练算力估算与 GPU 资源配置
笔记·深度学习·学习·自然语言处理·transformer
丝斯20111 小时前
AI学习笔记整理(75)——Python学习4
人工智能·笔记·学习
ID_180079054731 小时前
小红书笔记详情API深度解析:数据获取与应用实践
笔记
JulyLi20191 小时前
RK3576 yolov8部署笔记
笔记·yolo
小帅学编程1 小时前
英语学习笔记
java·笔记·学习
AI成长日志1 小时前
【datawhale】hello agents开源课程学习记录第4章:智能体经典范式构建
学习·开源