`
wb284551926
  • 浏览: 551336 次
文章分类
社区版块
存档分类
最新评论

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的问题。

 

原文地址:http://blog.itpub.net/21601207/viewspace-745088/

分享到:
评论

相关推荐

    基于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++编写,支持存储各种复杂的数据类型,尤其擅长处理大量的数据。它的数据模型与传统的关系...

    MongoDB使用手册

    MongoDB使用手册是数据库管理员和开发者的宝贵资源,它涵盖了MongoDB的各种操作、管理以及最佳实践。MongoDB是一个流行的开源、非关系型数据库系统,以其灵活性、可扩展性和高性能著称。以下是一些核心的MongoDB知识...

    spring-data使用mongodbTemplate对MongoDB进行读写操作

    在`App.java`中,你可以看到如何初始化和使用`MongoDBTemplate`。通常,你需要通过`ApplicationContext`获取`MongoDbFactory`,然后使用这个工厂创建`MongoDBTemplate`实例。 ```java ApplicationContext context =...

    《Node应用程序构建:使用MongoDB和Backbone》 源码

    5. **Express框架**:在Node.js中,Express是最广泛使用的Web应用框架,简化了路由设置、中间件使用和视图渲染。学习如何使用Express构建RESTful API,是构建Node.js应用的基础。 6. **Backbone.js的Model和...

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

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

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

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

    mongodb安装包和compass

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

    使用MyBatisPlus的方式,优雅的操作MongoDB

    使用MyBatisPlus的方式,优雅的操作MongoDB使用MyBatisPlus的方式,优雅的操作MongoDB使用MyBatisPlus的方式,优雅的操作MongoDB使用MyBatisPlus的方式,优雅的操作MongoDB使用MyBatisPlus的方式,优雅的操作MongoDB...

    mongoDB内部分享和交流

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

    Mongodb使用手册

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

    mongodb常用函数使用案例

    mongodb常用函数使用案例,主要是针对update,insert,find函数

    spark 连接 mongodb 使用例子

    本示例将讨论如何使用Java语言在Spark中连接MongoDB进行CRUD(创建、读取、更新和删除)操作,同时涉及到Spring框架和Maven构建工具。 首先,我们需要确保已安装并配置了Spark、Java、MongoDB以及Maven。在Java项目...

    FineReport如何连接和使用MongoDB数据库

    随着NoSQL数据库越来越流行,MongoDB数据库作为NoSQL数据库中的领头羊,使用也越来越广泛。为此,FineReport V8.0版本提供了数据连接和数据集接口,可以通过开发一款可以连接和使用的MongoDB数据库的插件。

    windows下mongodb安装与使用整理

    - 为了方便管理和使用 MongoDB,建议将其安装为 Windows 服务。 - 在命令提示符中输入以下命令: ``` >D:\mongodb\bin>mongod --dbpath "D:\mongodb\data\db" --logpath "D:\mongodb\data\log\MongoDB.log" --...

Global site tag (gtag.js) - Google Analytics