MongoDB概念

一、MongoDB 非关系型数据库同关系数据对应关系


对应关系如下图:


1、 文档 (document) MongoDB 中数据的基本单元,非常类似于关系型数据库系统中的行-一条记录 ( 但是比行要复杂的多 )

2、 集合 (collection) 就是一组文档,如果说 MongoDB 中的文档类似于关系型数据库中的行,那么集合就如同表 集合没有固定的结构,这意味着你在对集合可以插入不同格式和类型的数据

3、 MongoDB 的单个计算机可以容纳多个独立的数据库,每一个数据库都有自己的集合和权限

4、 MongoDB 自带简洁但功能强大的 JavaScript shell ,这个工具对于管理 MongoDB 实例和操作数据作用非常大

5、 每一个文档都有一个特殊的键” _id”, 它在文档所处的集合中是唯一的,相当于关系数据库中的表的主键

二、MongoDB的应用场景

(1)表结构不明确且数据不断变大

MongoDB是非结构化文档数据库,扩展字段很容易且不会影响原有数据。内容管理或者博客平台等,例如圈子系统、存储用户评论之类的。

(2)更高的写入负载

MongoDB侧重高数据写入的性能,而非事务安全,适合业务系统中有大量低价值数据的场景。本身存的就是json格式数据。例如做日志系统。

(3)数据量很大或者将来会变得很大

MySQL表数据量达到5-10G时会出现明细的性能降级,需要做数据的水平和垂直拆分、库的拆分完成扩展,MongoDB内建了sharding、很多数据分片的特性,容易水平扩展,比较好的适应大数据量增长的需求。

(4)高可用性

自带高可用,自动主从切换(副本集)http://database.51cto.com/art/201711/557797.htm

不适用的场景

(1)MongoDB不支持事务操作,需要用到事务的应用建议不用MongoDB

(2)MongoDB目前不支持join操作,需要复杂查询的应用也不建议使用MongoDB




版权声明:本文为sdausxc原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。