MongoDB文档--基本概念

阿丹:

        不断拓展自己的技术栈,不断学习新技术。

基本概念

MongoDB中文手册|官方文档中文版 - MongoDB-CN-Manual

 mongdb是文档数据库

MongoDB中的记录是一个文档,它是由字段和值对组成的数据结构。MongoDB文档类似于JSON对象。字段的值可以包括其他文档,数组和文档数组。

文档数据库

        文档数据库是一种数据库模型,它专门用于存储和管理非结构化数据,例如文档、文本和半结构化数据。相比传统的关系型数据库,文档数据库通过将数据组织为灵活的文档集合来提供更高的灵活性和扩展性。

        在文档数据库中,数据以类似于JSON或BSON的文档格式存储,每个文档可以具有不同的结构和字段。这使得文档数据库适用于处理动态数据、半结构化数据或需要频繁变更模式的应用程序。

        另一个重要的概念是文档数据库的查询能力。文档数据库提供了强大且灵活的查询功能,允许开发人员按需检索和操作存储的文档数据。这些查询可以使用结构化查询语言,如MongoDB的查询语言,或通过API进行编程。

        总的来说,文档数据库提供了一种高度灵活的存储和查询解决方案,适合那些需要存储非结构化数据并保持灵活性的应用程序。

使用文档优点:

  • 文档(即对象)对应于许多编程语言中的内置数据类型。

  • 嵌入式文档和数组减少了对昂贵连接的需求。

  • 动态模式支持流畅的多态性。

JSON(JavaScript Object Notation)和BSON(Binary JSON)都是用于表示结构化数据的格式,常用于文档数据库中的文档存储。

JSON是一种轻量级的数据交换格式,易于理解和使用。它使用人类可读的文本格式,采用键值对的形式来表示数据。JSON文档由嵌套的键值对组成,可以包含字符串、数字、布尔值、数组、嵌套的对象等数据类型。JSON格式非常适合简单的数据结构和基本的数据交换。

BSON是JSON的二进制表示形式,旨在提供更高的效率和更紧凑的存储方式。BSON使用二进制编码,以二进制形式表示JSON文档的键值对。与JSON相比,BSON格式存储更加紧凑,减少了存储空间和数据传输的需求,同时提供了更高的读写性能。

BSON支持的数据类型包括字符串、整数、浮点数、日期时间、布尔值、数组、嵌套的文档对象等。它还可以表示特殊类型,如正则表达式、JavaScript代码和二进制数据。BSON还提供了对数据类型的扩展,以支持更复杂的数据结构和功能,例如时间戳、最小、最大值等。

由于BSON的二进制表示形式,它在存储和传输数据时更加高效,并且能够更好地适应文档数据库的要求。因此,BSON是许多文档数据库(如MongoDB)中常用的文档存储格式。

下面是一个bson格式的示例

\x16\x00\x00\x00                          // 整个文档的大小
\x02                                      // 数据类型为字符串
name\x00                                 // 字段名
\x0C\x00\x00\x00John\x00        // 字段值为字符串 "John"
\x10                                      // 数据类型为整数
age\x00                                   // 字段名
\x1E\x00\x00\x00                          // 字段值为整数 30
\x00                                      // 数据类型为结束符

 集合/视图/按需实例化视图

MongoDB将文档存储在集合中。集合类似于关系数据库中的表。

除集合外,MongoDB还支持:

  • 只读视图(从MongoDB 3.4开始)

  • 按需实例化视图(从MongoDB 4.2开始)。

mongdb中的集合

数据库和集合 - MongoDB-CN-Manual

在MongoDB中,集合是文档的组,类似于关系数据库中的表。集合存在于数据库中,集合没有固定的结构,这意味着集合内的文档可以有不同的字段。

集合有以下主要特点:

  1. 集合存在于数据库中,一个数据库可以有多个集合。
  2. 集合类似于关系数据库中的表,但集合没有固定的结构。不同的文档可以有不同的字段。
  3. 集合中的每个文档都有一个主键_id来唯一标识。
  4. 集合可以通过名称来标识,当首次存储文档时会自动创建集合。
  5. 一个集合可以存储任意多个文档。
  6. 集合不会强制执行模式(schema),所以同一个集合中的文档可以有不同的字段。
  7. 集合会继承数据库的权限管理。

mongdb中的只读视图

Views — MongoDB Manual

 只读视图的使用业务场景

  1. 数据隔离:在某些情况下,我们需要将不同的用户或应用程序隔离开来,让他们只能访问自己需要的数据,而不能修改或删除其他人的数据。只读视图可以帮助我们实现数据隔离,保护数据的安全性和完整性。
  2. 数据审计:只读视图可以用于数据审计,即对数据进行审查和验证。通过只读视图,我们可以方便地查看数据,而不能修改或删除数据,确保数据的完整性和准确性。
  3. 数据共享:只读视图也可以用于数据共享,让不同的用户或应用程序共享数据,但不允许他们修改或删除数据。这样,我们可以确保数据的安全性和完整性,同时让更多的人能够方便地使用数据。

mongdb中的按需实例化视图

又称按需式物化视图,是MongoDB4.2最强大的新增功能之一

按需实例化视图是在MongoDB中一种特殊的只读集合,它会根据用户的查询需求,动态地实例化视图。与传统的只读视图不同,按需实例化视图不会提前创建视图,而是在每次查询时实时创建,并根据查询条件过滤数据。

按需实例化视图可以有效地减少存储空间和计算资源的使用,因为只有在需要查询数据时才会创建视图,并过滤出符合条件的数据。此外,按需实例化视图还可以提高查询性能,因为它们不会受到固定视图所带来的限制,可以更灵活地过滤数据。

在MongoDB中,按需实例化视图可以通过使用$merge阶段来创建。$merge阶段可以将管道结果的集合合并到现有集合中,而不是完全替换集合。这个特性使得按需实例化视图成为可能。通过在管道中添加$merge阶段,我们可以将聚合结果写入到现有集合中,并在需要时动态地实例化视图。

按需实例化视图在某些情况下非常有用,例如当我们需要动态地过滤数据,并根据查询条件实时生成视图时。通过使用按需实例化视图,我们可以更加灵活地处理数据,并确保数据的安全性和完整性。

水平拓展

MongoDB提供水平可伸缩性作为其_核心_ 功能的一部分:

  • 分片将数据分布在一个集群的机器上。

  • 从3.4开始,MongoDB支持基于分片键创建数据区域。在平衡群集中,MongoDB仅将区域覆盖的读写定向到区域内的那些分片。有关 更多信息,请参见区域章节。

支持多种存储引擎

MongoDB支持多个存储引擎:

  • WiredTiger存储引擎(包括对静态加密的支持 )

  • 内存存储引擎。

另外,MongoDB提供可插拔的存储引擎API,允许第三方为MongoDB开发存储引擎。

← MongoDB手册内容

原文链接:Introduction to MongoDB — MongoDB Manual

使用场景

 MongoDB是一种文档型数据库,具有高性能、高伸缩性和易用性等特点,适用于多种场景。以下是一些MongoDB的使用场景:

  1. 实时数据分析:MongoDB可以快速处理大量数据,并提供实时数据分析功能,适用于网络分析、业务智能、市场分析等场景。
  2. 游戏开发:MongoDB适合存储游戏用户信息、装备、积分等数据,并提供强大的查询和更新功能,提高游戏开发效率。
  3. 物流管理:MongoDB可以存储订单信息、订单状态、物流信息等数据,并提供灵活的查询和更新功能,帮助物流企业提高管理效率。
  4. 社交网络:MongoDB适合存储用户信息、朋友圈信息、地理位置信息等数据,并提供了强大的查询和数据分析功能,适用于社交网络应用。
  5. 物联网:MongoDB可以存储智能设备信息、设备汇报的日志信息等数据,并提供了实时查询和分析功能,适用于物联网应用。
  6. 视频直播:MongoDB可以存储用户信息、礼物信息等数据,并提供了高伸缩性和实时查询功能,适用于视频直播应用。

总之,MongoDB适用于需要处理大量数据、需要高伸缩性和实时查询的场景,可以提供高效的数据存储、查询和分析功能,帮助企业提高业务效率和竞争力。

mongdb的使用原因

MongoDB之所以被广泛使用,是因为它具有以下优点:

  1. 文档型数据库结构:MongoDB采用文档型数据库结构,可以存储各种类型的数据,如文本、数字、日期、二进制数据等,而且数据存储不需要固定的结构,可以灵活地插入和更新数据。
  2. 高性能:MongoDB使用了内存映射文件的方式,将数据存储在内存中,提高了读写速度和性能。
  3. 高扩展性:MongoDB支持分片集群,可以将数据分布在多个节点上,提高系统的扩展性和可靠性。
  4. 查询语言丰富:MongoDB支持丰富的查询语言,可以轻松地查询和过滤数据。
  5. 易于使用:MongoDB提供了丰富的的主流客户端库和语言驱动程序,可以方便地与各种应用程序进行集成。
  6. 社区支持:MongoDB拥有一个活跃的社区,提供了大量的的问题解决方案和工具,使得开发人员可以更加轻松地解决技术问题。

综上所述,MongoDB具有文档型数据库结构、高性能、高扩展性、查询语言丰富、易于使用和社区支持等优点,使得它成为一种广泛使用的数据库。

mongdb的同类产品对比

MongoDB与其他数据库产品相比,具有以下特点:

  1. 文档型数据库结构:MongoDB采用文档型数据库结构,可以存储各种类型的数据,如文本、数字、日期、二进制数据等,而且数据存储不需要固定的结构,可以灵活地插入和更新数据。
  2. 高性能:MongoDB使用了内存映射文件的方式,将数据存储在内存中,提高了读写速度和性能。
  3. 高扩展性:MongoDB支持分片集群,可以将数据分布在多个节点上,提高系统的扩展性和可靠性。
  4. 查询语言丰富:MongoDB支持丰富的查询语言,可以轻松地查询和过滤数据。
  5. 易于使用:MongoDB提供了丰富的主流客户端库和语言驱动程序,可以方便地与各种应用程序进行集成。

相比其他数据库产品,MongoDB在文档型数据库结构、高性能、高扩展性、查询语言丰富、易于使用等方面具有优势。但是,每个数据库产品都有其适用的场景和优势,需要根据具体的应用需求来选择最合适的数据库产品。

Cassandra,CouchDB,Redis,Riak,Hbase同类型产品

Cassandra、CouchDB、Redis、Riak和HBase都是流行的数据库产品,每个产品都有其自己的特点和优缺点。

以下是对这些产品与MongoDB的对比和优缺点的简要概述:

  1. Cassandra: Cassandra是高度可扩展的,能够处理大规模数据,并提供了强大的写入和读取性能。它的分布式特性使其能够轻松地跨多个节点进行数据复制和故障恢复。但是,Cassandra的使用相对复杂,需要一定的技术水平。
  2. CouchDB: CouchDB是一个高度可扩展的数据库,具有良好的容错性和可靠性。它使用文档存储数据,并支持全文搜索和附件处理。CouchDB的使用相对简单,但是它的性能相对较差,可能不适合高负载应用。
  3. Redis: Redis是一个内存数据库,具有非常高的读写性能和快速的数据访问速度。它支持多种数据结构,如字符串、哈希、列表、集合和有序集合。但是,Redis的存储容量受到内存限制,不适合存储大量数据。
  4. Riak: Riak是一个高度可扩展的分布式数据库,能够处理大规模数据。它具有良好的容错性和可靠性,并支持多种数据类型和查询语言。Riak的使用相对简单,但是它的性能相对较差,可能不适合高负载应用。
  5. HBase: HBase是一个分布式键值存储数据库,具有高性能和可扩展性。它能够处理大量数据,并支持多种数据类型和查询语言。但是,HBase的使用相对复杂,需要一定的技术水平。

相比之下,MongoDB具有文档型数据库结构、高性能、高扩展性、查询语言丰富、易于使用等优点。但是,每个数据库产品都有其适用的场景和优势,需要根据具体的应用需求来选择最合适的数据库产品。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/60082.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

使用ChatGPT编写技术文档

技术文档对于任何项目都是至关重要的,因为它确保所有利益相关者都在同一层面上,并允许有效的沟通和协作。创建详细而准确的技术文档可能既耗时又具有挑战性,特别是对于那些不熟悉主题或缺乏强大写作技巧的人来说。ChatGPT 是一个强大的人工智…

对python中多态详细教程

前言 嗨喽,大家好呀~这里是爱看美女的茜茜呐 一、多态 多态是指一类事物有多种形态,比如动物类,可以有猫,狗,猪等等。 (一个抽象类有多个子类,因而多态的概念依赖于继承) import…

【使用bat脚本实现批量创建文件夹、批量复制文件至对应文件夹中】

使用bat脚本实现批量创建文件夹、批量复制文件至对应文件夹中 常用cmd命令 场景一:在指定位置批量创建文件夹 在桌面创建一个txt文件编写创建目录代码 //在桌面"五保户结算单"的文件夹下创建名称为"1张三"的文件夹 md E:\桌面\五保户结算单\…

【深度学习_TensorFlow】感知机、全连接层、神经网络

写在前面 感知机、全连接层、神经网络是什么意思? 感知机: 是最简单的神经网络结构,可以对线性可分的数据进行分类。 全连接层: 是神经网络中的一种层结构,每个神经元与上一层的所有神经元相连接,实现全连接。 神经…

2023年08月IDE流行度最新排名

点击查看最新IDE流行度最新排名(每月更新) 2023年08月IDE流行度最新排名 顶级IDE排名是通过分析在谷歌上搜索IDE下载页面的频率而创建的 一个IDE被搜索的次数越多,这个IDE就被认为越受欢迎。原始数据来自谷歌Trends 如果您相信集体智慧&am…

京品优送元宇宙 上海布袋除尘器后一家太平洋百货月底停业

上海布袋除尘器后一家太平洋百货即将停业。 7月31日,上海太平洋百货微信公号发布公告称,由于与合资方的合作期限今年届满,上海太平洋百货徐汇店将于2023年8月31日营业结束后正式谢幕,终止经营,并于即日起开展大型主题感…

开放式蓝牙耳机哪个品牌好用?盘点几款很不错的开放式耳机

​相比传统入耳式耳机,开放式耳机因其不入耳不伤耳的开放设计,不仅带来了舒适的佩戴体验,还创造了一种与周围环境互动的全新方式,户外运动过程时也无需担心发生事故,安全性更高。我整理了几款比较好用的开放式耳机给大…

食品厂能源管理系统助力节能减排,提升可持续发展

随着全球能源问题的日益突出,食品厂作为能源消耗较大的行业,如何有效管理和利用能源成为了一项重要任务。引入食品厂能源管理系统可以帮助企业实现节能减排,提高能源利用效率,同时也符合可持续发展的理念。 食品厂能源管理系统的…

go程序使用tcp短连接报:only one usage of each socket address

环境及现象 Win10上位机(C#,WPF)后台使用go作为服务。 连接情况 C#连接大概60个TCP长连接(设备)。 后台go服务连接60个UDP短连接(设备附属硬件), 10个TCP短连接(PLC,modbus通讯&a…

了解国家电网

参考网站: https://www.dlzstp.com 参考网站: https://zhuanlan.zhihu.com/p/99743123 中国电网分为国家电网和南方电网两个大型电网集团,南方电网管理广东、广西、海南、云南、贵州5省电网,国网管理除这5个省外的26个省市、市…

P1173 [NOI2016] 网格

题目提供者洛谷 难度NOI/NOI/CTSC 历史分数100 题目描述 跳蚤国王和蛐蛐国王在玩一个游戏。 他们在一个 n 行 m 列的网格上排兵布阵。其中的 cc 个格子中 (0 ≤ c ≤ n⋅m),每个格子有一只蛐蛐,其余的格子中,每个格子有一只跳蚤。 我们…

安卓证书生成教程

1.下载安装JDK文件(如已安装请跳过) 根据电脑系统版本下载JDK版本文件 下载地址:[https://www.oracle.com/java/technologies/downloads/](https://www.oracle.com/java/technologies/downloads/) 如果电脑上安装过JDK文件可以跳过2.生成密钥…

解决mvn clean install遇到testng单元测试失败时打包也失败的问题

解决mvn clean install遇到testng单元测试失败时打包也失败的问题 看这个之前请先看这个 Jenkins执行Testng 比如我现在就有一个单元测试失败的项目 执行mvn clean install的时候就会报错 下面是我现在的pom.xml 但我们不希望这样&#xff0c;怎么办 <plugin><gr…

【JVM】(一)深入理解JVM运行时数据区

文章目录 一、JVM 运行流程二、虚拟机栈&#xff08;线程私有&#xff09;三、本地方法栈 &#xff08;线程私有&#xff09;四、方法区&#xff08;元数据区&#xff09;五、堆&#xff08;线程共享&#xff09;六、程序计数器&#xff08;线程私有&#xff09; 一、JVM 运行流…

【C++】开源:sqlite3数据库配置使用

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍sqlite3数据库配置使用。 无专精则不能成&#xff0c;无涉猎则不能通。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一下&#xff0c;下…

winform学习(3)-----Windows窗体应用和Windows窗体应用(.Net Framework)有啥区别?

1.模板选择 在学习winform的时候总是会对这两个应用不知道选择哪个&#xff1f;而且在学习的时候也没有具体的说明 首先说一下我是在添加控件的时候出现了以下问题 对于使用了Windows窗体应用这个模板的文件在工具箱中死活不见控件。 在转换使用了Windows窗体应用(.NET Fram…

性价比最高的护眼台灯是哪一款?性价比高的护眼台灯盘点

现在的孩子&#xff0c;不是以往的孩子那么的无忧无虑&#xff0c;他们要考虑的是学习的成绩&#xff0c;所以很多孩子为了能在父母面前能得到夸奖&#xff0c;就努力的学习&#xff0c;那么台灯就不可缺少&#xff0c;但是如今市场上的台灯太多了&#xff0c;如果你购买的台灯…

element表格+表单+表单验证结合u

一、结果展示 1、图片 2、描述 table中放form表单&#xff0c;放输入框或下拉框或多选框等&#xff1b; 点击添加按钮&#xff0c;首先验证表单&#xff0c;如果存在没填的就验证提醒&#xff0c;都填了就向下添加一行表单表格&#xff1b; 点击当前行删除按钮&#xff0c;…

linux鲁班猫屏幕和触摸[初用鲁班猫切换屏幕为MIPI-1080P][旋转屏幕为横屏显示][屏幕和触摸方向永久修改]

初用鲁班猫切换屏幕为MIPI-1080P 鲁班猫信息: 板卡从如下地址采购:https://detail.tmall.com/item.htm?_u110jcean66aa&id694560455663&spma1z09.2.0.0.56f52e8dj4eUdI&skuId5156903694777 鲁班猫官方文档和教程:https://doc.embedfire.com/linux/rk356x/quick_s…

【计算机视觉】BLIP:统一理解和生成的自举多模态模型

文章目录 一、导读二、背景和动机三、方法3.1 模型架构3.2 预训练目标3.3 BLIP 高效率利用噪声网络数据的方法&#xff1a;CapFilt 四、实验4.1 实验结果4.2 各个下游任务 BLIP 与其他 VLP 模型的对比 一、导读 BLIP 是一种多模态 Transformer 模型&#xff0c;主要针对以往的…