mongodb如何设计schema

我们都知道mongodb是一种面向文档的数据库,但是它的灵活性并不意味着你不需要对其进行结构设计,在代码实施之前进行结构设计是十分必要的。

但是这样问题就来了,目前我们用的几乎所有的数据库设计工具都无法表现出mongodb这种面向文档的数据结构,那么我们在做设计的时候怎么样把我们的结构清晰的展现给别人呢,我可不想用ps一个一个去画框图。

阅读 23.6k
3 个回答

其实官网的这篇设计哲学还是很不错的(http://www.mongodb.org/display/DOCS/S...)
MongoDB和传统SQL schema设计上最大的区别就是关于模型关系用什么方法表示比较好(在MongoDB里即可以用Link,又可以用Embedded)

简单总结下:

  1. FirstClass (比如“User”这种) 应该用独立的Collection
  2. "条目类型"的,应该 embedded
  3. 两个模型之间如果是包含关系,用 embedded
  4. 多对多关系,用 link(类似sql里面的foregin key)
  5. 如果一个模型,其可能存的对象很少,那么就用独立的collection,这样有助于mongodb server做缓存
  6. embedded方式不利于做复杂的关联,复杂的查询
  7. embedded方式性能很有优势,如果你有“性能”方面的要求,可以考虑用embbed
新手上路,请多包涵

我还是习惯吧mongodb当普通db看待,把collection看作表,每个collection里的数据结构保持一致。
不知道这样是否合理,至少这样让我思路比较清晰。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题