MongoDB概念

MongoDB是一种非结构化文档数据库,擅长处理表结构不明确、数据不断变大的情况,如内容管理和评论系统。其高写入负载性能适合日志系统,内置的分片特性适应大数据量增长,自带高可用性。然而,MongoDB不支持事务和join操作,不适合需要事务和复杂查询的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、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



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值