MongoDB 是什么和使用场景概述(技术选型)

2023-09-20 11:34:46

一、从NOSQL(Not Only SQL)说起 

       常见的数据库可以分为下面的两种类型:

  • RDBMS(关系型数据库):常见的关系型数据库有 Oracle、DB2、Microsoft SQL Server、Microsoft Access、MySQL;
  • NoSQL(非关系型数据库):常见的非关系型数据库有 MongoDB、Redis、Voldemort、Cassandra、Riak、Couchbase、CouchDB 等。

为什么使用 NoSQL?

          NoSQL 全称为“Not only SQL” ,表示非关系型数据库, MongoDB 就是非关系型数据库的一种。随着互联网不断发展,传统关系型数据库在处理超大规模数据以及高并发应用时已经显得力不从心了,而非关系型的数据库则由于其本身特点得到了非常迅速的发展。NoSQL 数据库的产生就是为了解决大规模数据集合多重数据种类带来的问题,特别是大数据应用的难题。

        不过,使用 NoSQL 数据库并不一定需要处理大数据。NoSQL(Not Only SQL)是一类非关系型数据库,相比传统的关系型数据库,它更注重可扩展性、高性能和灵活性。

        尽管 NoSQL 数据库在处理大规模数据时具有优势,但其应用场景不仅限于大数据。以下是一些使用 NoSQL 数据库的常见情况

  1. 高性能读写需求:NoSQL 数据库通常以键值对或文档形式存储数据,可以提供快速的读写操作。适用于对响应时间和吞吐量有较高要求的应用,不论数据规模大小。

  2. 灵活的数据模型:NoSQL 数据库不需要遵循固定的表结构,可以动态添加字段,适用于数据结构多变或者半结构化数据的存储和查询。

  3. 分布式环境和横向扩展:NoSQL 数据库天生支持分布式架构,可以方便地进行数据分片和横向扩展,以应对不断增长的数据负载。

  4. 处理大量低价值数据:虽然大数据环境下常使用 NoSQL 数据库,但对于包含大量低价值数据的应用,使用 NoSQL 数据库可以降低存储和维护成本。

        总之,NoSQL 数据库的使用并不仅限于大数据场景,它在高性能、灵活性和分布式环境等方面的特点,使得它可以适用于各种规模和类型的应用。选择是否使用 NoSQL 数据库应基于具体需求和应用场景来决定。

二、MongoDB 是什么

        MongoDB是一种面向文档的NoSQL数据库系统。它采用了JSON格式的BSON文档来存储数据,每个文档都有自己的键值对组成的结构。MongoDB具有以下特点:

  1. 强调灵活的数据模型:MongoDB的文档模型非常灵活,不需要提前定义表结构,可以根据需要动态添加、修改字段。这使得处理半结构化数据或者需求频繁变更的应用更加便捷。

  2. 高性能:MongoDB支持水平扩展,可以在集群中添加更多的节点来增加处理能力。同时,它也支持索引、聚合等功能,提供了快速的查询和聚合操作,适合高并发和大规模读写的场景。

  3. 分布式和容错性:MongoDB天生支持分布式部署,可以将数据分片存储在不同的节点上,提高了横向扩展和容错性能。

  4. 多种数据存储方式:除了传统的单节点方式外,MongoDB也支持副本集和分片集群模式,以满足不同规模和性能需求。

三、MongoDB 使用场景

        在以下场景下,MongoDB是一个很好的选择:

  1. 文档型数据:如果你的应用需要处理半结构化的数据,或者数据结构经常变化,MongoDB的灵活性和无需预定义模式的特点非常适合。

  2. 大规模数据处理:MongoDB的分布式架构和水平扩展能力使其在处理大数据量和高并发读写的场景下表现出色。

  3. 实时分析和聚合:MongoDB提供了丰富的聚合操作和强大的查询功能,适用于实时分析和数据挖掘应用。

  4. 原型开发和敏捷开发:MongoDB对数据模型的灵活性和动态添加字段的能力,使得原型开发和敏捷开发过程更加高效和灵活。

细化到具体的场景下,目前主要有:

移动应用

        MongoDB 支持二维空间索引,可以高效地查询地理位置关系和检索用户地理位置数据,很好地支撑基于地理位置查询的移动类 App 的业务需求。 同时 MongoDB 动态模式存储方式也非常适合存储多重系统的异构数据,满足移动 App 应用的需求。

物流应用

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

视频直播

        视频直播行业会产生大量的礼物信息,用户聊天信息等,数据量较大,使用 MongoDB 可存储用户信息、礼物信息以及日志等信息,同时可通过丰富的聚合查询来进行业务分析。

        总之,MongoDB是一款强调灵活性、高性能和可扩展性的NoSQL数据库,适用于半结构化数据、大规模数据处理和实时分析等场景,以及需要迅速迭代和快速开发的应用。

更多推荐

【深度学习】 Python 和 NumPy 系列教程(十一):NumPy详解:3、数组数学(元素、数组、矩阵级别的各种运算)

目录一、前言二、实验环境三、NumPy0、多维数组对象(ndarray)多维数组的属性1、创建数组2、数组操作3、数组数学1.元素级别a.直接运算b.加法:np.add()函数c.减法:np.subtract()函数d.乘法:np.multiply()函数e.除法:np.divide()函数f.幂运算:np.power

WIFI6特性分析

特性介绍wifi6作为全新一代wifi协议,提供了更快速度,信道利用率更高,抗干扰能力更强,更高的频宽,更好的待机表现。下边是对比wifi456三代特性的区别:OFDMA:正交多频分址,提升物理媒介的并发通信能力。MU-MINO:多用户上传下载,提升多用处场景wifi速率160MHZ:拓展频段宽度TWT:休眠唤醒机制,

php外贸代购系统网站,淘宝代购系统,淘宝代购集运系统,海外代购系统

PHP外贸代购系统网站建设需要以下步骤:链接各大热门商城上的商品并自动获取参数,程序集成了淘宝、拍拍等大型热门商城抓取规则,可以直接一键代购上面的任何商品,自动获取相应的参数。确定网站功能,如:产品展示、在线购物、搜索引擎等。选择适合的数据库,例如MySQL、PostgreSQL等,存储网站的数据信息。根据目标用户的需

【leetcode 力扣刷题】栈—波兰式///逆波兰式相关知识和题目

波兰式、逆波兰式相关知识和题目波兰式、逆波兰式介绍常规表达式转换成逆波兰式==编程让常规表达式转换成逆波兰式==逆波兰式运算过程常规表达式转换成波兰式==编程让常规表达式转换成波兰式==波兰式运算过程150.逆波兰式表达式求值224.基本计算器227.基本计算器Ⅱ282.给表达式添加运算符波兰式、逆波兰式介绍我们常看到

计算机毕业设计 基于SpringBoot餐厅点餐系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍:✌从事软件开发10年之余,专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌🍅文末获取源码联系🍅👇🏻精彩专栏推荐订阅👇🏻不然下次找不到哟————————————————计算机毕业设计题目《10

个人简历内容

简历个人信息专业技能熟悉Java基础,如集合、代理、反射等。了解Java多线程,了解JVM内存模型、常见GC算法、类加载机制。·#熟悉SSM+SpringBoot框架,熟悉AOP、IOC和SpringBoot自动配置原理,了解SpringMVC执行流程。熟悉MySQL数据库,熟悉InnoDB存储引擎、事务、MVCC机制

2023年云南省职业院校技能大赛中职组“网络安全”赛项样题

2023年云南省职业院校技能大赛中职组“网络安全”赛项样题一、竞赛时间总计:180分钟二、竞赛阶段竞赛阶段任务阶段竞赛任务竞赛时间分值A、B模块A-1登录安全加固180分钟200分A-2数据库加固A-3服务加固SSH\VSFTPDA-4防火墙策略B-1隐写术应用-B400分B-2内存取证B-3数据库渗透B-4Linux

信息检索与数据挖掘 | (二)布尔检索与倒排索引

文章目录📚词项-文档关联矩阵🐇相关名词🐇词项-文档关联矩阵的布尔查询处理📚倒排索引🐇关于索引🐇建立索引🐇基于倒排索引的布尔查询处理🐇查询优化📚字典数据结构🐇哈希表🐇各种树🐇B树vsB+树📚短语查询及含位置信息的倒排记录🐇二元词索引(Biwordindexes)🐇位置信息索引🐇混合索引机制

Hadoop学习总结(搭建Hadoop集群的安装准备)

目录一、安装jdk1、查看电脑中安装的jdk版本2、安装jdk173、配置path(配置jdk)4、对jdk8和jdk17版本做自由切换二、安装vmware三、安装centos7(虚拟机)四、虚拟机设置五、虚拟机网络配置1、查看NAT的网段2、修改主机名(1)修改虚拟机的hosts(2)修改虚拟机的hostname3、

Spring MVC 中的数据绑定和验证机制是什么,如何使用

在SpringMVC应用中,数据绑定和验证是非常重要的一部分,它们可以帮助我们将用户提交的数据绑定到Java对象上,并对数据进行验证,保证数据的正确性和可靠性。在SpringMVC中,数据绑定和验证机制都是通过注解来实现的。本文将介绍SpringMVC中的数据绑定和验证机制,以及如何使用它们。数据绑定数据绑定是将用户提

SSM整合(细节拉满)|将Mybatis、Spring、SpringMVC三个框架整合起来,通过一个demo来练习

环境要求环境:IDEAMySQL5.7.19Tomcat9Maven3.6要求:需要熟练掌握MySQL数据库,Spring,JavaWeb及MyBatis知识,简单的前端知识;数据库环境创建一个存放书籍数据的数据库表,并插入一些示例数据SSM整合新建一个空的Maven项目导入相关依赖将数据库与IDEA连接起来把项目结构

热文推荐