MongoDB数据模型设计

  MongoDB的数据模式是一种灵活模式,其集合并不限制文档结构。这种灵活性让对象和数据库文档之间的映射变得很容易,即使数据记录之间有很大的变化,每个文档也可以很好的映射到各条不同的记录。但在实际使用中,同一个集合中的文档往往都有一个比较类似的结构。

  描述文档结构的方式主要有两种:引用及内嵌。

内嵌

  内嵌的方式指的是把相关联的数据保存在同一个文档结构之中。MongoDB的文档结构允许一个字段或者一个数组内的值作为一个嵌套的文档。如果使用内嵌文档模型,应用程序只需查询一次就可以获得所有需要的信息。

 1 {
 2     _id:ObjectId("cccc"),
 3     name:"wddpct",
 4     age:22,
 5     location:"wenzhou",
 6     addresses:[
 7         {country:"china",city:"wenzhou",street:"chashan road"}
 8         {country:"china",city:"wenzhou",street:"north center road"}
 9     ]
10 }

一般来说,下述情况建议使用内嵌数据:
  1. 数据对象之间有包含关系。
  2. 数据对象之间有一对多的关系。

引用

  引用方式通过存储链接或者引用信息来实现两个不同文档之间的关联。应用程序可以通过解析这些数据库引用来访问相关数据。类似关系型数据库的关联查询。

 1 {
 2     _id:ObjectId("cccc"),
 3     name:"middle1",
 4     location:"wenzhou",
 5     students:[
 6         ObjectId("xxxx"),
 7         ObjectId("yyyy"),
 8         ……
 9     ]
10 }

一般来说,下述情况下适合使用引用方式:
  1. 当内嵌数据会导致很多数据的重复,并且读性能的优势又不足于覆盖数据重复的弊端
  2. 需要表达比较复杂的多对多关系的时候
  3. 大型层次结果数据集

通用建议

以下给出一张较通用的建议表,仅供参考

内嵌引用
子文档较小子文档较大
数据不会定期更改数据经常改变
最终数据一致即可中间阶段数据也必须一致
文档数据小额增加文档数据大幅增加
数据通常需要执行二次查询数据通常不包含在查询结果中
快速读取快速写入

转载于:https://www.cnblogs.com/leanfish/p/8795765.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值