MongoDB文档设计

mongodb设计法则
MongoDB 表设计

Mongodb文档设计(主要考虑读和更新的频率)

参考文档

1. 基础篇

考虑因数:一对多中的多是否需要一个单独实体
提出三个类型:内嵌、子引用、父引用

1.1、一对很少

适合内嵌文档

1.2. 一对许多

子级引用

    以一产品多零件为例,每个零件都有自己的文档对象(part),
      每个产品的文档对象(products)中以数组(catalog_number)存放多零件的objectID    
      为了快速执行查询,必须确保products.part和part_id存在索引,提高查询速度
      缺点:在修改一个零件,需要到所有引用该零件的产品进行更新(需考虑读写频率)
1.3. 一对非常多

一个收集各种机器日志为例 ---->父级引用

由于每个mongodb文档有16M的大小限制,直接存储objectID内存不足
“父级引用”  :用一个文档存储主机,在每个日志文档中保存这个主机的ObjectID

2.提升篇

双向关联、反范式化

2.1 双向关联

任务追踪系统,有person和task两个集合,在各自的集合中都有相关联的对象id

为了快速的获取某个用户负责的项目可以在task对象中嵌入附加的person引用关系
缺点:无法保证操作的原子性,使用该方法,先确认用例是否能允许该操作
2.2 反范式化

你将可能无法对冗余数据进行原子更新
只有读写比较高的情况下才采用反范式化设计

2.2.1 反范式many >> one

以产品(project)和零件(part)为例,在产品(project)中冗余存储零件的名字

产品中保存零件名
 考虑问题:考虑产品和零件的修改频率,
  零件变化的频率高,付出的更新代价高
  零件变化的频率低,付出的更新代价低
2.2.2 反范式 one >> many

冗余产品的名字到零件表

一旦更新产品的名字就必须更新所有和这个产品有关的零件
  这个比只更新一个产品对象来说代价明显更大,更要慎重考虑读写频率

总结

1、优先考虑内嵌,除非有什么迫不得已的原因。
2、需要单独访问一个对象,那这个对象就不适合被内嵌到其他对象中。
3、数组不应该无限制增长。
    如果many端有数百个文档对象就不要去内嵌他们可以采用引用ObjectID的方案;
    如果有数千个文档对象,那么就不要内嵌ObjectID的数组。
    该采取哪些方案取决于数组的大小。
4、不要害怕应用层级别的join:如果索引建的正确并且通过投影条件限制返回的结果,
    那么应用层级别的join并不会比关系数据库中join开销大多少。
5、在进行反范式设计时请先确认读写比。一个几乎不更改只是读取的字段才适合冗余到其他对象中。
6、在MongoDB中如何对你的数据建模,取决于你的应用程序如何去访问它们。
    数据的结构要去适应你的程序的读写场景。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,544评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,430评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,764评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,193评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,216评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,182评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,063评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,917评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,329评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,543评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,722评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,425评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,019评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,671评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,825评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,729评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,614评论 2 353