【数据库】MongoDB 简介:一种文档数据库

news2024/11/24 20:46:19

MongoDB 简介:一种文档数据库

  • 1.MongoDB 介绍
  • 2.MongoDB 数据存储方式
  • 3.MongoDB 概念与操作
    • 3.1 Create Operations
    • 3.2 Read Operations
    • 3.3 Update Operations
    • 3.4 Delete Operations
  • 4.MongoDB 特点
  • 5.MongoDB 应用场景

1.MongoDB 介绍

MongoDB 是一个基于分布式文件存储的开源 NoSQL 数据库系统,是由 C++ 编写的。MongoDB 是一个文档数据库,旨在简化开发和扩展。在许多场景下,MongoDB 可以用于代替关系型数据库或者键 / 值存储方式,为 Web 应用提供可扩展的高可用高性能数据存储解决方案。

2.MongoDB 数据存储方式

MongoDB 中的记录是一个文档,它是由字段和值对组成的数据结构,MongoDB 文档类似于 JSON 对象,字段的值可以包括其他文档,数组和文档数组。
在这里插入图片描述
使用文档的优点是:

  • 文档(即对象)对应于许多编程语言中的内置数据类型;
  • 嵌入式文档和数组减少了对昂贵连接的需求;
  • 动态模式支持流畅的多态性。

MongoDB 数据库将数据存储在集合 collections 中,而不是表 table。集合包含一个或者多个 BSON 文档。一个 BOSN 文档代表一条记录,而若干纪录组成一个集合 Collection。数据库中的集合就像这样:

在这里插入图片描述
BSON 是一种二进制形式的存储格式,简称 Binary JSON,和 JSON 一样,支持内嵌的文档对象和数组对象。但是 BSON 有 JSON 没有的一些数据类型,比如说 Date 和 BinData 类型。

BSON 采用了类似于 C 语言结构体的名称,具有轻量级、可遍历性、高效性三大特点,可以有效描述非结构化数据和结构化数据,灵活性高,但是空间利用率不是很理想。

BSON 中除了基本的 StringintegerBooleandoublenullarrayobject,MongoDB 还支持一些特殊的数据类型:dateobject idRegular ExpressionJavaScriptTimestamp

3.MongoDB 概念与操作

对应于关系数据库表,其中的一些概念和术语如下:

在这里插入图片描述
表级操作相关的各种 SQL 语句以及相应的 MongoDB 语句如下:

在这里插入图片描述
MongoDB 中的 CRUD 操作如下:

3.1 Create Operations

在集合中增加一个新的文档,集合不存在的话,则新建一个。有如下操作:

  • db.collection.insertOne()
  • db.collection.insertMany()

在 MongoDB 中,insert 操作的对象都是单个集合,而所有的写操作都是在单个文档级别的原子操作。

在这里插入图片描述

3.2 Read Operations

查询集合中的文档,也就是查询文档集合。 有如下操作:

  • db.collection.find()

查询操作可以指定返回文档的查询筛选条件。

在这里插入图片描述

3.3 Update Operations

修改现有集合中的文档。有如下操作:

  • db.collection.updateOne()
  • db.collection.updateMany()
  • db.collection.replaceOne()

更新操作是针对单个集合,所有写操作都是单个文档级别的原子操作。更新可以指定筛选条件,和查询条件具有相同语法。

在这里插入图片描述

3.4 Delete Operations

从集合中删除文档。有如下操作:

  • db.collection.deleteOne()
  • db.collection.deleteMany()

删除操作是针对单个集合。和改查一样,同样可以指定删除条件,语法和两者相同。

在这里插入图片描述

4.MongoDB 特点

MongoDB 是一种开源文档型数据库管理系统,开发者可以使用它来存储和处理大量的非结构化数据,对比关系型数据库,MongoDB 具有更高的可伸缩性、更好的性能和更灵活的数据类型。

在这里插入图片描述

  • 高可伸缩性:MongoDB 采用了分片技术,可以将数据分散在多台服务器上,从而实现水平扩展。这种方式无需增强单个服务器的性能,就可以满足不断增长的数据存储需求。

  • 高性能:查询速度快,部分原因是它将数据存储在内存中,还因为采用了多线程和异步 IO 技术,对大量并发请求也能有出色的响应能力。

  • 灵活的数据类型:采用文档型数据模型,通过嵌套文档和数组,可以灵活的表示数据。

  • JSON 编码:使用 BSON 格式类存储数据,BSON 上文已经提到,是 JSON 的二进制编码,具有更高的查询速度以及更少的存储空间。MongoDB 支持直接读写 JSON 格式的数据,提供了 JSON 风格的查询语言。

  • 可扩展性:存储引擎是可插拔式的,可以根据存储需求选择合适的存储引擎。

  • 自动分片:大型应用所需数据量庞大,MongoDB 可以自动分片,自动分配数据至不同服务器。

  • 数据备份与恢复:快照和复制技术实现数据备份和恢复。

5.MongoDB 应用场景

作为 NoSQL 数据库,MongoDB 可以解决关系型数据库无法解决的 High Performance、Huge Storage、High Scalability && High Availability 问题,分别是对数据库高并发读写的需求、对海量数据的高效率存储和访问的需求、对数据库的高可扩展性和高可用性的需求。

正因为如此,MongoDB 才可以在如下场景中得以应用:

  • 🚀 使用 MongoDB 存储游戏用户信息、装备、积分等,直接以内嵌文档的形式存储,方便查询、更新;
  • 🚀 存储订单信息、订单状态、物流信息;
  • 🚀 存储用户信息,朋友圈信息,通过地理位置定位;
  • 🚀 物联网中存储设备信息、设备汇报的日志信息并进行多维度分析;
  • 🚀 存储用户信息、点赞互动信息;
  • 🚀 ……

适用于 MongoDB 的场景总结:数据量大、读写操作频繁、数据价值不高,对事务要求不高

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Node——Node.js简介

Node.js是一个基于Chrome V8引擎的JavaScript运行时环境,它能够让JavaScript脚本运行在服务端,这使得JavaScript成为与PHP、Python等服务端语言平起平坐的脚本语言。 1、认识Node.js Node.js是当今网站开发中非常流行的一种技术,它以简单易…

Eureka简单使用做微服务模块之间动态请求

创建一个eureka模块,引入eureka 为启动项加上EnableEurekaServer注解 配置信息 orderService和userService的操作是一样的 这里以orderService为例: 引入eureka客户端 加上 LoadBalanced注解 配置 orderService和userService都配置好了之后 启动 这样我们在http://localhos…

Matplotlib画图接口_Python数据分析与可视化

Matplotlib画图接口 导入matplotlib显示图像画图接口 导入matplotlib 和numpy,pandas一样,在导入matplotlib时我们也可以用一些常用的简写形式: import matplotlib as mpl import matplotlib.pyplot as pltpyplot是最常用的画图模块接口,功…

KaiwuDB 亮相中国 5G + 工业互联网大会,助力新型工业化

11月19-21日,由各相关政府部门共同主办的“2023 中国 5G工业互联网大会”在湖北武汉盛大举行。作为我国“5G工业互联网”领域的国家级顶会,本届大会以“数实融合,大力推进新型工业化”为主题,聚焦新型基础设施、产业转型升级、技术…

麒麟V10服务器搭建FTP服务

概念 1.1介绍 FTP:File transfer protocol 文件传输协议 1.2原理 默认采用被动模式 被动模式FTP 为了解决服务器发起到客户的连接的问题,人们开发了一种不同的FTP连接方式。这就是所谓的被 动方式,或者叫做PASV,当客户端通…

计算机组成原理-Cache替换算法

文章目录 总览随机算法(RAND)先进先出算法(FIFO)近期最少使用算法(LRU)最不经常使用算法(LFU)总结 总览 随机算法(RAND) 没有选择性地考虑替换哪一块Cache&a…

Glare or Gloom, I Can Still See You – End-to-End Multi-Modal Object Detection

SENSOR-AWARE MULTI-MODAL FUSION G-log(-log(U)),U~Uniform[0,1] 辅助信息 作者未提供代码

解密Spring Cloud微服务调用:如何轻松获取请求目标方的IP和端口

公众号「架构成长指南」,专注于生产实践、云原生、分布式系统、大数据技术分享。 目的 Spring Cloud 线上微服务实例都是2个起步,如果出问题后,在没有ELK等日志分析平台,如何确定调用到了目标服务的那个实例,以此来排…

深度学习笔记《一》:keras_core.layers.Conv2D()

一、说明 卷积,池化,激活函数,这三者号称是深度神经网络的三驾马车;其中卷积是最复杂的一个,因此,对卷积这个东西需要精心认知,这样对后面学习大有帮助。本篇为系列博文,专门介绍Cer…

哈希表、哈希冲突解决办法

文章目录 一、什么是哈希表?二、什么是哈希冲突?怎样解决?三、哈希表的大小为什么是质数?四、链表法五、开放地址法线性探测法平方探测法双哈希(Double Hashing) 六、哈希表满了怎么办?七、完美哈希八、一些使用哈希解…

PGP 遇上比特币

重复使用 PGP 密钥作为比特币密钥 介绍 在数字安全领域,密码学在确保数据的完整性和真实性方面发挥着至关重要的作用。 一种广泛使用的加密技术是使用 Pretty Good Privacy (PGP1)。 PGP 为安全通信(例如电子邮件、文件传输和数据存储)提供加…

4G执法记录仪在高铁、地铁、机场应急处突中的应用

4G执法记录仪:高铁、地铁、机场紧急应对新利器 随着时代的迅猛发展,公共交通安全管理面临着越来越复杂的挑战。其中,高铁、地铁、机场这类人流密集的区域,要求高效、准确的应急响应与指挥调度机制。在这种背景下,4G/5G执法记录仪…

大数据平台/大数据技术与原理-实验报告--MapReduce编程

实验名称 MapReduce编程 实验性质 (必修、选修) 必修 实验类型(验证、设计、创新、综合) 综合 实验课时 2 实验日期 2023.10.30-2023.11.03 实验仪器设备以及实验软硬件要求 专业实验室(配有centos7.5系统…

burpsuite issue definitions

https://portswigger.net/burp/documentation/scanner/vulnerabilities-list 先从高危的开始学(四十能学剑,时人无此心): os command injection todo 未完待续

element 的 Notification 通知,自定义内容

通知事件: // 商户后台通知 MerchantBackgroundNotice() {// 禁止消息通知弹出多条if(this.notifyInstance) {this.notifyInstance.close();}const h this.$createElement; // 创建文本节点this.notifyInstance this.$notify({showClose: false, // 禁止关闭按钮…

Python语言学习笔记之三(字符编码)

本课程对于有其它语言基础的开发人员可以参考和学习,同时也是记录下来,为个人学习使用,文档中有此不当之处,请谅解。 什么是字符编码 计算机从本质上来说只认识二进制中的0和1,字符编码(Character Encoding) 是一种将…

Java(八)(可变参数,Collections,小案例:斗地主游戏小案例:斗地主游戏,Map集合,Stream流)

目录 可变参数 Collections 小案例:斗地主游戏 Map集合 Map的常用方法 map集合的遍历 键找值 键值对 Lambda 表达式 HashMap底层原理 集合的嵌套 Stream流 获取集合或数组的Stream流 Stream流的方法 可变参数 就是一种特殊的形参,定义在方法和构造器的形参列表中,…

视频没有字幕怎么办,怎么给视频增加字幕

文章目录 视频没有字幕怎么办,怎么给视频增加字幕前言软件准备制作字幕1. 导入视频2. 将视频拖拽到轨道3. 生成字幕4. 导出字幕 字幕实时翻译1. 播放视频2. 显示字幕设置3. 双语字幕显示 总结 视频没有字幕怎么办,怎么给视频增加字幕 前言 有时候下载的…

传音荣获2023首届全国人工智能应用场景创新挑战赛“智能家居专项赛”三等奖

近日,中国人工智能学会与科技部新一代人工智能发展研究中心联合举办2023首届全国人工智能应用场景创新挑战赛(2023 1st China’s Innovation Challenge on Artificial Intelligence Application Scene,以下简称CICAS 2023),吸引了…

10 个例子带你学会 AI 编程(含提示词)

大家好,我是伍六七。 AI 编程是一个程序员群体普遍关注的领域,但是真的使用 AI 编程实现提效的还是少数。 有的人没有大模型资源,有的人不知道可以在哪些方面使用 AI 进行提效,还有的人不相信使用 AI 可以提效。 今天&#xff…