菁英职教网 I T Python

面向文档的数据库系统MongoDB详解

发布时间: 2022-05-28 06:55:01

面向文档的数据库系统MongoDB详解,MongoDB是一个面向文档的数据库系统。使用C++编写,不支持SQL,但有自己功能强大的查询语法。

数据库系统MongoDB
  MongoDB使用BSON作为数据存储和传输的格式。BSON是一种类似JSON的二进制序列化文档,支持嵌套对象和数组。

一、MongoDB很像MySQL,document对应MySQL的row,collection对应MySQL的table应用场景:

1、网站数据:

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

2、缓存:

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

3、大尺寸、低价值的数据:

使用传统的关系数据库存储一些数据时可能会比较贵,在此之前,很多程序员往往会选择传统的文件进行存储。

4、高伸缩性的场景:

mongo非常适合由数十或者数百台服务器组成的数据库。

5、用于对象及JSON数据的存储:

mongo的BSON数据格式非常适合文档格式化的存储及查询。

6、重要数据:

mysql,一般数据:mongodb,临时数据:memcache对于关系数据表而言,mongodb是提供了一个更快速的视图view;而对于PHP程序而言,mongodb可以作为一个持久化的数组来使用,并且这个持久化的数组还可以支持排序、条件、限制等功能。

二、将mongodb代替mysql的部分功能,主要一个思考点就是:把mongodb当作mysql的一个view(视图),view是将表数据整合成业务数据的关键。比如说对原始数据进行报表,那么就要先把原始数据统计后生成view,在对view进行查询和报表。不适合的场景:

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

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

3、需要SQL的问题

4、重要数据,关系数据

优点:
  1)弱一致性(最终一致),更能保证用户的访问速度
  2)文档结构的存储方式,能够更便捷的获取数
  3)内置GridFS,高效存储二进制大对象(比如照片和视频)
  4)支持复制集、主备、互为主备、自动分片等特性
  5)动态查询
  6)全索引支持,扩展到内部对象和内嵌数组

缺点:

1)不支持事务
  2)MongoDB占用空间过大,维护工具不够成熟

温馨提示:
本文【面向文档的数据库系统MongoDB详解】由作者职教君提供。该文观点仅代表作者本人,菁英职教网系信息发布平台,仅提供信息存储空间服务,若存在侵权问题,请及时联系管理员或作者进行删除。
我们采用的作品包括内容和图片部分来源于网络用户投稿,我们不确定投稿用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的权利,请联系我站将及时删除。
内容侵权、违法和不良信息举报
Copyright @ 2024 菁英职教网 All Rights Reserved 版权所有. 七品教育网站地图xml 留求艺网站地图xml 湘ICP备17021685号