如何设计MongoDB数据模型

    有效的数据模型是为应用服务的,设计构架的关键问题是文档模型适合使用嵌入式模型(embed)还是使用引用模型(references)。


    嵌入式数据模型(Embedded Data Models)


    在MongoDB中,你可能将相关数据嵌入到一个单一结构或文档,这些模式通常被称为“非正规”模型,但是它充分利用了MongoDB富文档模型的有点。

spacer.gif

    嵌入式数据模型允许应用程序存储相关的信息在一条数据库记录中,这样应用程序可能需要更少的查询和更新来完成常规的操作。


    一般来说,嵌入式数据模型适用于以下场景:


    (1)拥有包含实体之间的关系


    (2)实体之间拥有一对多的关系,在这些关系中,“many”或子文档总是出现在或人为是“one”或富文档的上下文。


    通常情况下,嵌入数据的方式在读操作上提供了更好的性能,能够在单次数据操作中请求和检索相关的数据。嵌入式数据模型使MongoDB能够在一次原子写操作中更新相关的数据。


    然后,嵌入相关的数据,可能导致文档创建后文档增长太大的问题。文档增长会影响数据的写性能并导致数据分片。而且,MongoDB中文档的大小必须小于BSON格式规定的文档最大容量(最大的BSON文档大小是16MB)。对于大部分二进制数据,需要参考GridFS。


    与嵌入式文档进行交互,使用“.”符号进入嵌入文档。


    规范化数据模型(Normalized Data Models,References)

    

    规范化数据模型描述了文档引用之间的关系。

spacer.gif

    一般来说,规范化数据模型适用于以下场景:


    (1)当嵌入式数据模型会导致数据重复并且提供的读性能的优势不会重复的影响。


    (2)呈现许多复杂的多对多关系。


    (3)对大型分层数据集进行建模


    引用(References)模式比嵌入模式提供更好的灵活性,但是客户端应用程序必须解决引用的后续查询问题。换句话说,规范化数据模型需要更多轮的请求服务器。


    


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值