第十四天
今天要学习的是14、15、16、17章节。对比传统的模型设计方法,作者总结自己的经验,来讲解MongoDB是怎么样进行模型设计的,并举了一个分桶模型的例子。
关系模型与文档模型的对比
传统上来讲,由于MongoDB是通过文档来组织数据的,所以人们认为MongoDB是没有模型设计的,或者不需要模型设计的。其实不管是什么数据库,要想高效、易用的组织数据,模型设计是必不可少的,方式方法也是相通的。
JSON文档模型设计
- 文档模型设计处于物理模型设计阶段,逻辑结构与物理结构基本是一样的。
- JSON文档模型通过内嵌数组或者引用字段来表示关系
- 文档模型设计不遵循关系数据库设计的第三范式,允许冗余。
例子
在一个文档中实现了所有数据的组织,当然还没考虑性能及易用性等等方面,后面展开。
作者给出的设计步骤
个人理解就是,整理出实体/属性/关系,然后再考虑系统的环境、读写的性能、数据的容量等因素调整设计,最后就是看看能不能套用一些设计模型的最佳实践。
联系人管理例子
什么时候该使用引用方式
- 内嵌文档太大,数 MB 或者超过 16MB
- 内嵌文档或数组元素会频繁修改
- 内嵌数组元素会持续增长并且没有封顶
MongoDB 引用设计的限制
- MongoDB 对使用引用的集合之间并无主外键检查
- MongoDB 使用聚合框架的 $lookup 来模仿关联查询
- $lookup 只支持 left outer join
- $lookup 的关联目标(from)不能是分片表
经验小结
- 90:10 规则:大部分时候你会使用内嵌来表示 1-1,1-N,N-N
- 内嵌类似于预先聚合(关联)
- 内嵌后对读操作通常有优势(减少关联)
分桶模式
说简单点就是得用内嵌数组将一个时间段的数据集合到一个文档中,而不是传统的按行存.
适用范围
最后
今天的内容就这些,举的几个例子比较不错,可以反复琢磨一下
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。