美文网首页代码改变世界MongoDB@IT·互联网
MongoDB开发系列:从数据集合的设计开始

MongoDB开发系列:从数据集合的设计开始

作者: needrunning | 来源:发表于2017-05-11 19:51 被阅读363次


MongoDb中集合概念就是关系型数据库中的表,本文讨论的内容主要集中在MongoDb数据库库设计集合时关键原则和常见的设计误区。

第一条准则

抛弃关系型数据库设计的范式约束,摒弃关联查询。先考虑内嵌形式,再考虑引用,视使用场景而定。

MongoDb的设计原则建议多种对象以关联嵌套的方式组织在一个文档中,方便应用程序一次读取。

注意这里说的是建议,不是【必须】,因为有特定场景下,完全嵌套是不能满足存储需求的。

第二条准则

文档中不是每个字段都必须有值,也就是每行的字段可以不一致。控制字段尽量不插入null值和空值,这样可以节约内存存储,MongoDb中的稀疏索引类型专门为【不是每个文档都有的字段】而设计。

这种特性适合Iot数据采集类似的使用场景,每个文档的字段数目不等,按需插入。

注意这种情况下,切忌文档过宽。那如何避免这种情况,我的方法是预估最大字段数,以20个字段为节点,多于20则采用嵌套document的设计方式组织document。

第三条准则

时间可以直接定义为格式化的时间,便于识别和查询。不必特意存储时间戳,这样方便可视化的工具查询核对。

"create_time" : ISODate("2017-05-10T15:39:58.000+08:00"),

第四条准则

字段长度尽可能的短,不宜过长。也是考虑到内存优化。

新概念

分桶设计原则

我们知道许多传感器数据都是时间序列数据。例如:风传感器,潮汐监测以及位置追踪等采集数据的无非这种类型: Timestamp,采集器名称/ID,采集值。对于时序类型的数据,我们可以采用一种叫做时间分桶的优化策略。

所谓分桶优化,就是与其对每一条数据创建一个文档,我们可以把某一个时间段内的测量数据聚合到一起放到一个文档内,利用MongoDB提供的内嵌式数组或子文档特性

参考资料

http://www.mongoing.com/mongodb-advanced-pattern-design

http://www.tuicool.com/articles/Uv6zYnv

https://segmentfault.com/q/1010000002943721

相关文章

  • MongoDB开发系列:从数据集合的设计开始

    MongoDb中集合概念就是关系型数据库中的表,本文讨论的内容主要集中在MongoDb数据库库设计集合时关键原则和...

  • MongoDB 学习笔记

    MongoDB 简介 MongoDB 是为快速开发互联网 WEB 应用而设计的数据库系统。MongoDB 的设计目...

  • MongoDB开发系列-集合更新

    本文主要介绍MongoDB数据库中Update的主要操作场景,阅读本篇文章您将了解到以下内容 MongoDB中Up...

  • MongoDB初识及启动

    mongoDB的存储结构 数据库->集合->子集合->文档 文档:是mongoDB存储数据的最小集合,就是js的一...

  • MongoDB基本用法

    简介(https://www.mongodb.com/) MongoDB是为了快速开发互联网Web应用而设计的数据...

  • MongoDB 常用基本命令

    mongoDB 数据库 mongoDB 数据库概念 集合 文档 _id mongo命令 链接MongoDB 数...

  • mongodb学习笔记

    1、MongoDB特点 面向集合存储:MongoDB 是面向集合的,数据以 collection 分组存储。每个 ...

  • MongoDB 基础浅谈

    1 MongoDB 特点 面向集合存储:MongoDB 是面向集合的,数据以 collection 分组存储。每个...

  • Docker安装MongoDB

    MongoDB是什么? mongoDB是存储文档的非关系型数据库。 MongoDB的文档结构 集合 集合中可以包...

  • mongo查询操作符

    一 基本概念 MongoDB中数据的结构为:库、集合、文档 1 数据库 多个集合可以组成数据库。MongoDb的单...

网友评论

    本文标题:MongoDB开发系列:从数据集合的设计开始

    本文链接:https://www.haomeiwen.com/subject/kyvktxtx.html