mongodb数据合并设计_MongoDB数据建模

本文探讨了MongoDB数据建模的灵活性,指出在设计时需要考虑应用需求、性能和数据检索模式。以博客网站为例,解释了一个集合如何存储文章标题、描述、标签、作者信息、评论等数据,对比了与RDBMS架构的差异,强调MongoDB中数据合并的优势。
摘要由CSDN通过智能技术生成

MongoDB中的数据具有灵活的模式。文档在同一集合,但它们不需要具有相同的字段或结构集合,集合文档中的公共字段可以包含不同类型的数据。

MongoDB中的数据具有灵活的模式。与SQL数据库不同,SQL数据库必须在插入数据之前确定和声明表的模式,MongoDB的集合不会强制执行文档结构。这种灵活性有助于将文档映射到实体或对象。 每个文档可以匹配表示实体的数据字段,即使数据具有实质性的变化。然而,集合中的文档具有类似的结构。

数据建模中的关键挑战是平衡应用程序的需求,数据库引擎的性能特征和数据检索模式。 在设计数据模型时,请始终考虑数据的应用程序使用情况(即数据的查询,更新和处理)以及数据本身的固有结构。

在MongoDB中设计架构时有一些考虑:

根据用户要求设计架构。

将对象合并到一个文档中,否则分开它们(但确保不需要连接)。

复制数据(但有限制),因为与计算时间相比,磁盘空间便宜。

在写入时加入,而不是读取时加入。

为最常用的用例优化架构。

在模式中执行复杂聚合。

实例

假设客户需要他的博客/网站的数据库设计,并查看RDBMS和MongoDB架构设计之间的区别。网站有以下要求。

每个帖子都有唯一的标题,描述和网址。

每个帖子都可以有一个或多个标签。

每个帖子都有其发布者的名称和总人数。

每个帖子都有用户给出的评论以及他们的姓名,消息,数据时间和喜好。

每个帖子可以有零个或多个评论。

在RDBMS架构中,上述要求的设计将具有最少的三个表。表与表之间的关系如下 -

而在MongoDB模式中,设计将有一个集合post,其结构以下 -

{

_id: POST_ID

title: TITLE_OF_POST,

description: POST_DESCRIPTION,

by: POST_BY,

url: URL_OF_POST,

tags: [TAG1, TAG2, TAG3],

likes: TOTAL_LIKES,

comments: [

{

user:'COMMENT_BY',

message: TEXT,

dateCreated: DATE_TIME,

like: LIKES

},

{

user:'COMMENT_BY',

message: TEXT,

dateCreated: DATE_TIME,

like: LIKES

}

]

}

通过上面的示例说明可以知道,在显示数据时,在RDBMS中需要连接三个表,而在MongoDB中,数据将仅显示在一个集合中。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值