`
tiankong6622
  • 浏览: 55474 次
社区版块
存档分类
最新评论

谈MongoDB的应用场景

阅读更多

谈MongoDB的应用场景

 

MongoDB的应用场景在网上搜索了下,很少介绍关于传统的信息化应用中如何使用MongoDB数据库方面的内容,比较多的还是介绍日志的采集和存储,小文件的分布式存储,类似互联网微博应用的数据存储等方面的内容。在这里思考下传统企业信息化系统中的应用可行性。

首先对于NoSQL数据库,在数据库建模上需要重点考虑,彻底放弃传统的关系型数据库建模方法,如果将传统的关系型数据库表原封不动的映射到NoSQL数据库,很多NoSQL数据库本身的优点特性反而无用武之地。其中最重要的就是转化为面对对象的思维模式,更加关注领域对象和实体信息。MongoDB数据库的集合本身就是一个可以包罗万象的层次化的文档对象,集合本身还可以包含子集合,形成一个完整意义上的对象。

如果拿一个最简单的企业客户信息管理功能来说,可以看到首先要维护有哪些企业客户,企业客户的常用联系人,每个人的联系方式,企业相关的资料文档,企业的地址信息,企业的账户信息,争取企业的拜访记录等,这里讲的就是一个最简单的企业客户域的对象信息。

按道理来说企业信息就是一个完整的对象,企业附属对象都从属于企业这个对象,企业这个信息没有了其余附属对象信息的生命周期也就结束。如果按这个意义上来说只需要简历一个collection集合就可以管理所有事情。但是我看到企业客户包括了两方面信息,一个是偏静态信息,如企业基本信息,联系人,联系地址信息;一个是偏动态信息,即企业的拜访记录等。考虑了企业拜访记录本身变动频繁是动态信息,可以将企业拜访记录拆分出来单独做为一个文档对象来管理。如果这样的话,要完善以上功能只需要建两个文档对象,一个是企业客户基本信息,一个是拜访记录信息。另外还有一个文件存储功能,直接使用MongoDB的GridFS来完成即可。

在企业客户信息中,企业客户即一个集合,在该集合中联系人信息为子集合,联系人的联系方式(多种联系方式)信息可以有两点考虑,一个是子子集合,也可以直接将多种联系方式归并到联系人对象一层,由于MongoDB的属性字段本身就可以方便的扩展,这样设计可以减少整个集合的层次。(在这里我的考虑就是,对于1对多关系,对于子表本身就只有一个字段的都可以考虑合并到父对象里面减少层次)。这些信息往往在客户基本信息录入的时候就需要完整录入,一个完整的JSON对象格式可以很方便的作为一个整体存入到MongoDB数据库中。

对于客户的拜访记录由于动态经常增加,可以单独设置一个对象,在该对象中增加客户ID,客户名称信息冗余,减少后续查询功能中不必要的对象关联。对于这个对象我们可以看到会经常增加数据,但是实际增加的数据本身变动却很少。在拜访记录中如果还有和本次拜访相关的图片或文档存储,也可以很方面的解决问题。

对于客户文档资料存储,前面已经说过了直接使用GridFS来完成即可。GridFS是MongoDB的一个内置功能,它提供一组文件操作的API以利用MongoDB存储文件。对于刚才的场景可以看到,对于增加一个客户资料的存储首先调用文件存储API完成非结构化文件的存储,存储完成后可以返回文件句柄ID,这个句柄ID可以做为一个子集合直接存储在客户主Collection对象上,也可以单独建立一个客户ID和文件句柄ID的关联表,但是个人认为直接建立在客户主集合对象似乎更好。

基于以上基本思路来分析实际客户信息管理需要的具体功能点。

客户信息新增功能,在新增界面上需要维护客户基本信息,客户的联系人,地址信息,客户的文档资料信息,如果不考虑非结构文档附件,整个页面本身就是一个完整的JSON对象,可以只调用一次即完成整个层次化集合对象的存储,而且相当简单。考虑到附件信息,即操作分为两个步骤,首先上传存储附件获取附件句柄ID,然后再存储结构化客户基本对象信息。对于客户拜访记录信息,录入客户拜访记录首先肯定是要选择到具体的客户,选择到具体客户后,客户的ID信息,客户的名称信息即已经可以获取到。新增加一条拜访记录也是相当简单的操作即可以完成。

再来看查询功能,首先看客户信息查询可能是一个模糊查询功能,而MongoDB对模糊查询性能是比较弱的,因此尽可能的减少不必要模糊查询字段,对于必须的查询字段可以在MongoDB对象中增加相应的索引信息。最重要的就是基于MongoDB数据库对Join操作的支持很弱,应该在数据模型设计和查询设计上尽可能的减少不必要的对象关联操作。当查询到某一个具体的客户信息后,需要查看该客户具体的拜访记录就相当简单的,只是对拜访记录表最简单的根据客户ID的一个类where操作即可完成。对于客户具体的附件列表信息可以做相似的设计,即点击链接后再进入到具体的客户附件文档查看界面。

对于更新功能,基本对象的更新也相当简单,剩下的就是对于联系人信息的更新,联系人信息是一个子集合对象,在这里暂时还没有看到是需要对这个子集合对象全部更新掉,还是可以做到只更新操作子集合对象中的一条记录。对于更新操作,仍然需要定位到具体的ID值再进行更新。对于批量更新现在MongoDB本身也提供了相应的操作,类似批量更新客户状态操作还是很容易实现的。

以上只是一个最简单的分析,基于这种分析,以后对于类似主数据管理系统的应用完全可以迁移到MongoDB数据库来支撑。另外对于记录更新不频繁,对象直接相互关联和影响小的场景也适合迁移到MongoDB数据库。在NoSQL数据库的使用过程中应该尽量避开类似强一致性要求,表间关系复杂,长周期事务等场景。

 

原文出处:http://blog.sina.com.cn/s/blog_493a84550101e9a1.html

分享到:
评论

相关推荐

    Codeigniter集成mongodb

    集成MongoDB数据库意味着在CI项目中使用非关系型数据库(NoSQL)系统,这通常用于处理大规模数据或者需要高度可扩展性的应用场景。MongoDB以其灵活性、高性能和文档存储能力受到开发者的欢迎。 在CI中集成MongoDB,...

    MongoDB和MongoDB云数据库浅谈

    MongoDB的特点和适用场景 实用性  MongoDB是一个面向文档的数据库,它并不是关系型数据库,直接存取BSON,这意味着MongoDB更加灵活,因为可以在文档中直接插入数组之类的复杂数据类型,并且文档的key和value不是...

    数据库新技术与新应用--mongodb.docx

    2009 年 NoSQL 运动正式提出,代表性的数据库包括 MongoDB、Cassandra、HBase 和 Riak。 关系型数据库与分布式系统简介 关系型数据库基于 ACID(原子性、一致性、隔离性和持久性)原则,通过 SQL 查询语言实现数据...

    事务、高性能,王涛谈打造超越MongoDB的NoSQL

    多样性、大容量给数据的存储和处理带来了巨大的挑战,当传统关系型数据库无法应对应用程序的快速迭代时,天生具备弱数据结构模式、易扩展等特性的NoSQL数据库得以飞速发展,在众多网络及新型应用程序中得以部署。...

    SQL集合嵌套表varray

    本篇文章将详细探讨这两种数据类型,以及它们在实际应用中的优势和使用场景。 首先,集合嵌套表是一种可以存储多个行或列的表类型,这些行或列共享相同的结构,并且可以被视为单个单元。在Oracle数据库中,这种类型...

    架构革新高效可控_浅谈数据库服务和架构演讲V7.zip

    它包括关系型数据库(如MySQL、Oracle)、非关系型数据库(如MongoDB、Redis)等多种类型,服务于各种业务场景,如电子商务、社交网络、金融服务等。 2. **架构革新**:随着业务发展和技术进步,传统的数据库架构...

    JAVA互联网企业面试真题

    面试者需熟悉Spring Boot、Spring Cloud等微服务相关技术,并理解依赖注入、事务管理、AOP的使用场景。 数据库方面,SQL查询优化、索引原理、事务处理、存储过程等是面试常见问题。面试者还需了解NoSQL数据库,如...

    2013年中国数据库大会PPT第一部分

    9.主流开源NoSQL及分布式存储的应用与思考.pdf 10.腾讯在线交易平台统一数据层高一致性解决方案.pdf 11.NoSQL一致性实践:我对CAP的一点认识.pdf 12.MongoDB at Qihoo 360.pdf 13.MySQL Cluster实战初探 .pdf 14.SAP...

    080 北斗车联网大数据平台_大屏幕展屏(html源码).rar

    北斗车联网大数据平台是一款基于大屏幕展屏的html源码实现,它主要展示了如何将大数据技术应用于车载信息系统,为车辆管理、安全监控、运营优化提供强大的数据支持。此平台的源码设计涵盖了前端开发和大数据处理的...

    浅谈在koa2中实现页面渲染的全局数据

    在本场景中,开发者遇到了一个问题:每个页面都需要验证用户是否登录,并显示相应的个人信息。通过使用中间件,我们可以解决这个问题,实现数据的全局共享。 首先,我们导入必要的模块,例如`UserClient`,用于处理...

    new_test.rar_NEW_java 采集_采集入库

    在IT行业中,自动采集程序和数据入库是两个关键的技术领域,尤其在大数据处理、网站监控、搜索引擎优化(SEO)和数据分析等场景下显得尤为重要。本文将深入探讨这两个主题,并结合提供的压缩包文件进行分析。 标题...

    浅谈MySQL索引优化分析

    在面对高并发场景时,非关系型数据库如MongoDB因其高性能和弹性扩展性而受到青睐。然而,MongoDB在数据一致性、安全性及复杂查询上不如关系型数据库MySQL。MySQL提供强大的事务处理和复杂的查询功能,适用于需要保证...

    webbrowser 仿制 天涯社区:国际观察版(未完)

    数据库则可能选择MySQL、PostgreSQL或MongoDB等,存储用户数据和论坛内容。 总的来说,仿制天涯社区的国际观察版是一个涵盖前端开发、后端开发、数据解析、网络安全等多个领域的综合性项目。每个环节都需要扎实的...

    2013中国数据库大会ppt(1)

    主流开源NoSQL及分布式存储的应用与思考.pdf 腾讯在线交易平台统一数据层高一致性解决方案.pdf NoSQL一致性实践:我对CAP的一点认识.pdf MongoDB at Qihoo 360.pdf MySQL Cluster实战初探 .pdf SAP HANA深度剖析.pdf...

    2013中国数据大会ppt(2)

    主流开源NoSQL及分布式存储的应用与思考.pdf 腾讯在线交易平台统一数据层高一致性解决方案.pdf NoSQL一致性实践:我对CAP的一点认识.pdf MongoDB at Qihoo 360.pdf MySQL Cluster实战初探 .pdf SAP HANA深度剖析.pdf...

Global site tag (gtag.js) - Google Analytics