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

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)高可用性

自带高可用,自动主从切换(副本集)MongoDB概念

不适用的场景

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

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



相关文章: