导读:用MongoDB去存储非关系型的数据,是一个比较正确的选择。但是,如果只是用MongoDB,那么也会出现一些问题。MongoDB,尤其使用的最佳场景,更多的时候,需要结合关系型数据库共同解决问题。本篇博客,则介绍一下MongoDb在运用过程中可能出现的问题。

一、出现的问题

首先,我们先来简单看一下MongoDB的存储结构图(以电视节目为例):

那么以传统的关系型数据库存储,这将要建立好几张表,但如果用非关系型,则是:

<span style="font-family:KaiTi_GB2312;font-size:18px;">{title:'Angel's Class',
seasons:[
{
season_number:'1',
episodes:[
{
ordinal_within_season:'1',
title:'what is it',
reviews:[{...}],
cast_members:[{...}]
}
]
}
]
}
</span>

通过jsonArray的,只存储一个对象,就可以获得想要的数据。可是,问题也因此而来(以facebook的使用为例):

那么,以上的结构,如果以关系型数据库作为存储,当我们需要获取数据时,则需要联合查询好几张表。那么这时候,为了简便,以非关系型数据库作为存储的概念出来了,如下所示:

这时候,我们依然能通过存储一个对象,获取我们想要的数据。可是,当我们试图去更新着一条记录的时候,那么这将是项危险的操作,我们不得不去更改这个对象里涉及到的所有数据(也许只是想改个自己昵称而已)。(它的危险来源于:信息嵌套)

这个时候,或许我们需要引入id:

这时候,我们仍然可以通过一个文档去获取用户的完整数据,但对于里面涉及到的User2等数据,则需要在程序中去编写代码!

二、结合项目的思考

在最近做的今日开讲的项目中,那么作为讲师模块,一个添加或者编辑,需要操作5张表:Student,Teacher,UserFied,UserIndustry,WorkExperience,其中用户领域和行业、工作经验都可以是多个。那么我们用MySQL的时候,则每次都需要查4次,一次:联合Student和Teacher表,去获得用户的基本信息。其余的是,分别查询讲师的领域、行业和工作经验。

那么,在这个需求中,并不涉及到信息的嵌套和危险操作。如果使用Mongo的话,那么一个讲师只需要查询一个对象就可以获取出所有的数据。这样,在编程的时候,我们就可以更多的,以系统的业务逻辑实现去思考问题,而可以将数据的持久化操作暂时搁浅。

PS:后来想过了,这个系统在很多地方还是得用关系型的数据库(在非关系的数据库里,尽可能的不要去link你的document)。那么即使使用Mongo可以在一定程序一定范围内方便,但是对于整个的学习成本、时间成本、维护成本考虑,结合系统的规模来说,或许不是一个最佳的选择!

三、总结

在什么时候使用MySQL之类的数据库呢?当我们需要进行复杂的、多行的数据交易;高度事务性的系统。

在什么时候使用Mongo之类的数据库呢?个人观点:可以将Mongo(高性能)作为一个缓存用,避免下层数据的过载;作为视图(作为全局来看,Mongo的文档存储,其实很像关系型数据库中的视图 );存储Json对象,实时性的数据。

总结:在选择数据库的时候,很重要的一件事就是:明确业务需求,数据类型,让数据库(数据)为业务服务!

分享:在计算机科学中,最艰难的有两件事:缓存失效和命名!

MongoDB 3: 使用中的问题,及其应用场景的更多相关文章

  1. 谈谈mongodb,mysql的区别和具体应用场景

    最近对数据库比较感兴趣,于是就去研究了下部分相关热门的数据库. MySQL 关系型数据库. 在不同的引擎上有不同 的存储方式. 查询语句是使用传统的sql语句,拥有较为成熟的体系,成熟度很高. 开源数 ...

  2. MongoDB安装、CURD操作、使用场景分析总结(1)

    NoSQL(NoSQL = Not Only SQL ),意即"不仅仅是SQL".非关系型的数据存储 MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 ...

  3. mongodb适用和不适用的应用场景

    近期考虑把订单历史数据从Oracle数据库迁移到Nosql数据库做历史数据查询和分析,一天千万级数据.打算使用mongodb数据库.使用nodejs做查询和统计API,对并发请求量要求低,不知道有没有 ...

  4. MongoDB在实际项目中的使用

    MongoDB简介 MongoDB是近些年来流行起来的NoSql的代表,和传统数据库最大的区别是支持文档型数据库. 当然,现在的一些数据库通过自定义复合类型,可变长数组等手段也可以模拟文档型数据库. ...

  5. MongoDB在实际项目

    MongoDB在实际项目中的使用   MongoDB简介 MongoDB是近些年来流行起来的NoSql的代表,和传统数据库最大的区别是支持文档型数据库.当然,现在的一些数据库通过自定义复合类型,可变长 ...

  6. 疯狂了!当游戏爱上MongoDB会怎么样???

    导读 前端时间魔兽这个电影我相信大家都看过了哈,作为一个码农,有时候我也会去思考魔兽世界这个游戏背后他的一些设计和实现,比如他用什么数据库.当然真正用什么数据库这个我是不确定的,我们今天的主题是当游戏 ...

  7. 新年新技术:MongoDB 3.0

    前一篇介绍了HTTP/2,这一篇简单介绍下3月3号发布的MongoDB 3.0. What’s new in MongoDB 3.0? 新的存储引擎WiredTiger MongoDB 3.0的存储引 ...

  8. Redis、Memcache和MongoDB的区别

    >>Memcached Memcached的优点:Memcached可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS(取决于key.value的字节大小以及服务器硬件性能,日常环境 ...

  9. Python迁移MySQL数据到MongoDB脚本

    MongoDB是一个文档数据库,在存储小文件方面存在天然优势.随着业务求的变化,需要将线上MySQL数据库中的行记录,导入到MongoDB中文档记录. 一.场景:线上MySQL数据库某表迁移到Mong ...

随机推荐

  1. Objective-C语法汇总

    1.方法前的加减号 Objective-C中是没有public与private的概念的,即可以认为全部都是public.减号表示的是一个函数.方法.消息的开始.加号则表示不需要创建一个类的实例,其他类 ...

  2. ADF_ADF Faces系列4_ADF数据可视化组件简介之建立BarChart/Gauge/ExportExcel

    2013-05-01 Created By BaoXinjian

  3. RAC_Oracle集群服务安装Grid Infrastructure(案例)

    2015-01-24 Created By BaoXinjian Thanks and Regards

  4. ERP_Oracle Erp R12.2的新技术特点(概念)

    2014-09-09 Created By BaoXinjian

  5. [MySQL] 同步一张表、复制过滤设置

    一.缘由 据测试要求,需要把线上一张股票信息的表实时同步到测试环境,那么干吧,这次不复制库,单独复制表. 二.解决办法 可以按照同步(复制)库的方法来,在salve端设置 my.cnf,replica ...

  6. JAVA算数运算符

    算数运算符 序号 算数运算符 含义用法 特殊含义用法 1 + 加法 字符串连接 2 - 减法   3 * 乘法   4 / 除法   5 % 取余   实例: public class Test{ p ...

  7. js实现的新闻列表垂直滚动实现详解

    js实现的新闻列表垂直滚动实现详解:新闻列表垂直滚动效果在大量的网站都有应用,有点自然是不言而喻的,首先由于网页的空间有限,使用滚动代码可以使用最小的空间提供更多的信息量,还有让网页有了动态的效果,更 ...

  8. 30天轻松学习javaweb_模拟tomcat

    运行 javac Server.java 编译java文件 执行 java Server 运行程序 在ie中输入 http://localhost:9999/ 打开模拟的服务程序 import jav ...

  9. Jmeter Html 报告优化

    转载自南风_real博客园:http://www.cnblogs.com/jaychang/p/5881525.html 但是最近在查阅相关资料时,发现基本都是重复一篇文章Jmeter使用笔记之htm ...

  10. Zabbix监控和分布式部署实施方案

    最近在研究Zabbix监控,由于机房分布在多个城市,因此采用zabbix proxy做为监控方案,在每 个节点部署zabbix proxy,由zabbix proxy收集agentd数据,然后将采集到 ...