`
frank1998819
  • 浏览: 758278 次
  • 性别: Icon_minigender_1
  • 来自: 南京
文章分类
社区版块
存档分类

mongodb 使用场景和不使用场景(转)

 
阅读更多

1.mongodb介绍

MongoDB (名称来自"humongous") 是一个可扩展的高性能,开源,模式自由,面向文档的数据库。它使用C++编写。MongoDB特点:

a.面向集合的存储:适合存储对象及JSON形式的数据。

b.动态查询:mongo支持丰富的查询表达方式,查询指令使用JSON形式的标记,可轻易查询文档中的内嵌的对象及数组。

c.完整的索引支持:包括文档内嵌对象及数组。mongo的查询优化器会分析查询表达式,并生成一个高效的查询计划。

d.查询监视:mongo包含一个监视工具用于分析数据库操作性能。

e.复制及自动故障转移:mongo数据库支持服务器之间的数据复制,支持主-从模式及服务器之间的相互复制。复制的主要目的是提供冗余及自动故障转移。

f.高效的传统存储方式:支持二进制数据及大型对象(如照片或图片)。

g.自动分片以支持云级别的伸缩性:自动分片功能支持水平的数据库集群,可动态添加额外的机器。

2.mongo使用场合

mongodb的主要目标是在键/值存储方式(提供了高性能和高度伸缩性)以及传统的RDBMS系统(丰富的功能)架起一座桥梁,集两者的优势于一身。mongo适用于以下场景:

a.网站数据:mongo非常适合实时的插入,更新与查询,并具备网站实时数据存储所需的复制及高度伸缩性。

b.缓存:由于性能很高,mongo也适合作为信息基础设施的缓存层。在系统重启之后,由mongo搭建的持久化缓存可以避免下层的数据源过载。

c.大尺寸、低价值的数据:使用传统的关系数据库存储一些数据时可能会比较贵,在此之前,很多程序员往往会选择传统的文件进行存储。

d.高伸缩性的场景:mongo非常适合由数十或者数百台服务器组成的数据库。

e.用于对象及JSON数据的存储:mongo的BSON数据格式非常适合文档格式化的存储及查询。

不适合的场景:

a.高度事物性的系统:例如银行或会计系统。传统的关系型数据库目前还是更适用于需要大量原子性复杂事务的应用程序。

b.传统的商业智能应用:针对特定问题的BI数据库会对产生高度优化的查询方式。对于此类应用,数据仓库可能是更合适的选择。

c.需要SQL的问题。

分享到:
评论

相关推荐

    基于threejs的在线3D场景编辑器使用mongodb保存3D模型和场景数据

    标题中的“基于threejs的在线3D场景编辑器使用mongodb保存3D模型和场景数据”指的是一款使用Three.js库构建的Web应用程序,允许用户在浏览器中创建、编辑和保存3D场景。Three.js是JavaScript的一个强大库,专门用于...

    java中mongodb使用环境详细配置

    每次运行 MongoDB 需要使用命令行来启动,它并不方便。因此,用户可以将 MongoDB 安装为 Windows 服务。使用以下命令可以完成安装:D:\MongoDB\bin>mongod --logpath D:\MongoDB\logs\MongoDB.log --logappend --...

    MongoDB 应用场景与最佳实践.docx

    同时,英文比较好的小伙伴可以直接使用 MongoDB 官方的教程,视频教程中有英语字幕,听不懂的同学可以暂停观看字幕。 在学习 MongoDB 的时候,可以参照 MongoDB 官方的文档,文档地址选择自己想要看到的章节,文档...

    mongodb的安装和使用简介

    MongoDB是一种开源的非关系型数据库系统,其特点在于分布式文件存储、高性能、易部署、易使用和存储格式灵活。MongoDB采用C++编写,支持存储各种复杂的数据类型,尤其擅长处理大量的数据。它的数据模型与传统的关系...

    Thinkphp使用mongodb数据库实现多条件查询方法

    在Thinkphp中实现多条件查询时,可以使用框架提供的查询构建器(Query Builder),但是当涉及到MongoDB的复合查询时,比如需要使用AND和OR逻辑运算符进行多条件筛选,官方文档中提供的方法可能不足以满足需求。...

    mongodb安装包和compass

    MongoDB是一款开源、分布式、高性能的NoSQL数据库,它不使用传统的表格和列式结构来存储数据,而是采用键值对、文档、集合和图形数据模型。这种设计使得MongoDB在处理非结构化和半结构化数据时表现出色,特别适合大...

    MongoDB高级应用场景及技术特点分析.pptx

    这些应用场景都可以使用 MongoDB 的技术特点来实现高性能和高可扩展性的数据管理。 四、事务支持 MongoDB 4.2 版本开始支持事务操作,例如分布式多文档事务。事务操作可以确保数据的一致性和可靠性。 五、性能...

    mongoDB内部分享和交流

    9. **最佳实践**:总结MongoDB的使用过程中应遵循的一些最佳实践,以确保数据库的稳定性和效率。 10. **案例研究**:可能包含一些实际项目中的应用案例,展示MongoDB在不同场景下的解决方案。 通过深入学习和交流...

    Mongodb使用手册

    11. **云服务**:简要介绍MongoDB Atlas,这是MongoDB官方提供的云托管服务,包括其优势、配置选项和使用场景。 12. **最佳实践**:提供一系列实用的建议和最佳实践,帮助开发者避免常见问题,提高MongoDB的应用...

    mongodb 使用手册

    MongoDB 使用手册 MongoDB 是一个高性能、开源、无模式的文档型数据库,适用...了解并掌握其安装、使用和基本语法是开发过程中不可或缺的技能。通过阅读和实践本手册,你将能够熟练地运用MongoDB进行数据存储和处理。

    MongoDB开发使用手册.docx

    MongoDB 是一种流行的开源NoSQL数据库,主要用于处理大量的非结构化和半结构化数据。它以其灵活性、可扩展性和高性能而受...总的来说,了解并掌握MongoDB的基本使用和特性,对于现代Web应用的开发和数据管理至关重要。

    MongoDB数据库应用场景及技术特点.pptx

    MongoDB 使用文档模型来存储数据,而不是传统的关系型数据库中的表。文档模型具有灵活性和可扩展性,可以根据需要添加或删除字段。例如: { _id : 123456, first_name : "Mark", last_name : "Smith", city : "San ...

    mongoDB实现BOM表多试图转换

    对于大规模BOM数据,可以考虑使用MongoDB的分片和复制集特性,以保证系统扩展性和高可用性。 总之,通过MongoDB和Java的结合,我们可以高效地实现企业BOM表的多视图转换。这个过程涉及数据库设计、数据读写、转换...

    MongoDB开发使用手册.pdf

    描述:本文档旨在介绍 MongoDB 的开发使用手册,涵盖 MongoDB 的基本概念、NOSQL 的历史和产生原因、MongoDB 的特点和优势、MongoDB 的安装和配置、MongoDB 的数据模型、MongoDB 的查询语言、MongoDB 的索引和优化、...

    MongoDB数据库设计规范.docx

    MongoDB 的灵活模式和高可用性使得它非常适合大规模数据存储和处理的应用场景。 七、 设计规范重点 MongoDB 的设计规范重点在于确保数据的一致性和安全性。MongoDB 提供了多种机制来确保数据的一致性和安全性,...

    mongodb使用demo

    MongoDB支持丰富的查询条件,如基本的等于、不等于、范围查询,以及更复杂的正则表达式和数组匹配。例如: ```javascript db.users.find({name: "张三"}); ``` 如果要返回所有数据,可以使用`db.collection.find...

Global site tag (gtag.js) - Google Analytics