`

mongodb与mysql相比的优缺点

 
阅读更多

与关系型数据库相比,MongoDB的优点:
①弱一致性(最终一致),更能保证用户的访问速度:
举例来说,在传统的关系型数据库中,一个COUNT类型的操作会锁定数据集,这样可以保证得到“当前”情况下的精确值。这在某些情况下,例如通过ATM查看账户信息的时候很重要,但对于Wordnik来说,数据是不断更新和增长的,这种“精确”的保证几乎没有任何意义,反而会产生很大的延迟。他们需要的是一个“大约”的数字以及更快的处理速度。

 

但某些情况下MongoDB会锁住数据库。如果此时正有数百个请求,则它们会堆积起来,造成许多问题。我们使用了下面的优化方式来避免锁定:
每次更新前,我们会先查询记录。查询操作会将对象放入内存,于是更新则会尽可能的迅速。在主/从部署方案中,从节点可以使用“-pretouch”参数运行,这也可以得到相同的效果。 
使用多个mongod进程。我们根据访问模式将数据库拆分成多个进程。 
②文档结构的存储方式,能够更便捷的获取数据。
对于一个层级式的数据结构来说,如果要将这样的数据使用扁平式的,表状的结构来保存数据,这无论是在查询还是获取数据时都十分困难。
举例1:
就拿一个“字典项”来说,虽然并不十分复杂,但还是会关系到“定义”、“词性”、“发音”或是“引用”等内容。大部分工程师会将这种模型使用关系型数据库中的主键和外键表现出来,但把它看作一个“文档”而不是“一系列有关系的表”岂不更好?使用 “dictionary.definition.partOfSpeech='noun'”来查询也比表之间一系列复杂(往往代价也很高)的连接查询方便且快速。

 

举例2:在一个关系型数据库中,一篇博客(包含文章内容、评论、评论的投票)会被打散在多张数据表中。在MongoDB中,能用一个文档来表示一篇博客,评论与投票作为文档数组,放在正文主文档中。这样数据更易于管理,消除了传统关系型数据库中影响性能和水平扩展性的“JOIN”操作。

 

CODE↓
> db.blogposts.save({ title : "My First Post", author: {name : "Jane", id :1},
  comments : [{ by: "Abe", text: "First" },
              { by : "Ada", text : "Good post" }]
})

 

> db.blogposts.find( { "author.name" : "Jane" } )

 

> db.blogposts.findOne({ title : "My First Post", "author.name": "Jane",
  comments : [{ by: "Abe", text: "First" },
              { by : "Ada", text : "Good post" } ]
})
> db.blogposts.find( { "comments.by" : "Ada" } )

 

> db.blogposts.ensureIndex( { "comments.by" : 1 } );
举例③:
MongoDB是一个面向文档的数据库,目前由10gen开发并维护,它的功能丰富,齐全,完全可以替代MySQL。在使用MongoDB做产品原型的过程中,我们总结了MonogDB的一些亮点:
使用JSON风格语法,易于掌握和理解:MongoDB使用JSON的变种BSON作为内部存储的格式和语法。针对MongoDB的操作都使用JSON风格语法,客户端提交或接收的数据都使用JSON形式来展现。相对于SQL来说,更加直观,容易理解和掌握。
Schema-less,支持嵌入子文档:MongoDB是一个Schema-free的文档数据库。一个数据库可以有多个Collection,每个Collection是Documents的集合。Collection和Document和传统数据库的Table和Row并不对等。无需事先定义 Collection,随时可以创建。
Collection中可以包含具有不同schema的文档记录。 这意味着,你上一条记录中的文档有3个属性,而下一条记录的文档可以有10个属性,属性的类型既可以是基本的数据类型(如数字、字符串、日期等),也可以是数组或者散列,甚至还可以是一个子文档(embed document)。这样,可以实现逆规范化(denormalizing)的数据模型,提高查询的速度。

 

 

 

③内置GridFS,支持大容量的存储。
  GridFS是一个出色的分布式文件系统,可以支持海量的数据存储。
  内置了GridFS了MongoDB,能够满足对大数据集的快速范围查询。
④内置Sharding。
提供基于Range的Auto Sharding机制:一个collection可按照记录的范围,分成若干个段,切分到不同的Shard上。
Shards可以和复制结合,配合Replica sets能够实现Sharding+fail-over,不同的Shard之间可以负载均衡。查询是对客户端是透明的。客户端执行查询,统计,MapReduce等操作,这些会被MongoDB自动路由到后端的数据节点。这让我们关注于自己的业务,适当的时候可以无痛的升级。MongoDB的Sharding设计能力最大可支持约20 petabytes,足以支撑一般应用。
这可以保证MongoDB运行在便宜的PC服务器集群上。PC集群扩充起来非常方便并且成本很低,避免了“sharding”操作的复杂性和成本。

 

⑤第三方支持丰富。(这是与其他的NoSQL相比,MongoDB也具有的优势)
现在网络上的很多NoSQL开源数据库完全属于社区型的,没有官方支持,给使用者带来了很大的风险。
而开源文档数据库MongoDB背后有商业公司10gen为其提供供商业培训和支持。
而且MongoDB社区非常活跃,很多开发框架都迅速提供了对MongDB的支持。不少知名大公司和网站也在生产环境中使用MongoDB,越来越多的创新型企业转而使用MongoDB作为和Django,RoR来搭配的技术方案。
⑥性能优越:
在使用场合下,千万级别的文档对象,近10G的数据,对有索引的ID的查询不会比mysql慢,而对非索引字段的查询,则是全面胜出。 mysql实际无法胜任大数据量下任意字段的查询,而mongodb的查询性能实在让我惊讶。写入性能同样很令人满意,同样写入百万级别的数据,mongodb比我以前试用过的couchdb要快得多,基本10分钟以下可以解决。补上一句,观察过程中mongodb都远算不上是CPU杀手。

 


与关系型数据库相比,MongoDB的缺点:
①mongodb不支持事务操作。
  所以事务要求严格的系统(如果银行系统)肯定不能用它。(这点和优点①是对应的)
②mongodb占用空间过大。
  关于其原因,在官方的FAQ中,提到有如下几个方面:
1、空间的预分配:为避免形成过多的硬盘碎片,mongodb每次空间不足时都会申请生成一大块的硬盘空间,而且申请的量从64M、128M、256M那样的指数递增,直到2G为单个文件的最大体积。随着数据量的增加,你可以在其数据目录里看到这些整块生成容量不断递增的文件。

 

2、字段名所占用的空间:为了保持每个记录内的结构信息用于查询,mongodb需要把每个字段的key-value都以BSON的形式存储,如果 value域相对于key域并不大,比如存放数值型的数据,则数据的overhead是最大的。一种减少空间占用的方法是把字段名尽量取短一些,这样占用空间就小了,但这就要求在易读性与空间占用上作为权衡了。我曾建议作者把字段名作个index,每个字段名用一个字节表示,这样就不用担心字段名取多长了。但作者的担忧也不无道理,这种索引方式需要每次查询得到结果后把索引值跟原值作一个替换,再发送到客户端,这个替换也是挺耗费时间的。现在的实现算是拿空间来换取时间吧。

 

3、删除记录不释放空间:这很容易理解,为避免记录删除后的数据的大规模挪动,原记录空间不删除,只标记“已删除”即可,以后还可以重复利用。

 

4、可以定期运行db.repairDatabase()来整理记录,但这个过程会比较缓慢

 

③MongoDB没有如MySQL那样成熟的维护工具,这对于开发和IT运营都是个值得注意的地方。

 

分享到:
评论

相关推荐

    主流NoSQL数据库全方位评测:MongoDB.docx.docx

    MongoDB是一种非关系型(NoSQL)数据库,它以文档存储的方式管理数据,与传统的关系型数据库相比有着明显的区别。这种面向文档的设计使得MongoDB在灵活性和扩展性方面表现优异,能够很好地支持大规模的数据存储需求...

    3.1.1_非关系型数据库mongodb及其搭建1

    3. **大数据量**:当MySQL等关系数据库因数据量过大而性能下降时,MongoDB的分片机制可以实现水平扩展,应对大数据需求。 4. **高可用性**:MongoDB支持副本集,实现自动主从切换,确保服务的连续性。 **MongoDB的...

    java和C#和PHP和各种数据库优缺点.docx

    对于各种数据库,它们各有优缺点,例如关系型数据库如MySQL、Oracle以其结构化数据存储和SQL查询语言而著名,适合事务处理和复杂查询;NoSQL数据库如MongoDB、Couchbase则在大数据处理和非结构化数据存储方面表现...

    开源项目研究与应用小结.pdf

    - **缺点**:与Java相比,在高并发方面表现一般。 - **JavaScript**:Google V8引擎 + Node.js + MongoDB[MySQL] - **优点**:基于JavaScript的事件驱动模型,实现了前后端的统一。 - **缺点**:部分Node.js...

    NoSQL数据库入门思维导图

    综上所述,"NoSQL数据库入门思维导图"应包含了NoSQL的基本概念、主要类型、优缺点以及与MySQL的对比,帮助初学者理解并选择合适的数据库技术。通过“基础知识.mmap”可以深入学习NoSQL的原理和操作,而“常见的NoSQL...

    数据库常用面试题目_基础题

    - 请解释索引的优缺点,以及如何避免“索引失效”现象? 5. **事务处理** - 举例说明事务的四种隔离级别及其可能导致的问题。 - 如何解决死锁问题,有哪些预防策略? 6. **备份与恢复** - 请阐述数据库备份的...

    Python经典练习题合集(含分析+代码)

    - 数据库接口:Python与多种数据库兼容,如MySQL、SQLite、MongoDB和Redis,方便数据存储和管理。 - GUI编程:Python支持Tkinter、PyQt、wxPython等库,能创建图形用户界面,便于开发桌面应用程序。 缺点: - 运行...

    NoSQL深入了解,学习文档

    相比于传统的关系型数据库(如MySQL、Oracle),NoSQL数据库在灵活性、扩展性和性能方面具有显著优势。本学习文档将深入探讨NoSQL的原理、类型、优缺点以及实际应用。 一、NoSQL的基本概念 NoSQL数据库摒弃了传统...

    NoSQL技术培训 深入讲解

    总之,NoSQL技术以其独特的设计哲学,在特定领域展现了不可替代的优势,但也需根据具体业务场景权衡其优缺点,选择最适合的数据库解决方案。随着技术的不断发展,NoSQL数据库将持续进化,更好地服务于大数据时代的...

    javascript进阶.md

    #### 二、PHP简介及其优缺点 - **PHP简介** - **全称**:PHP最初是Personal Home Page的缩写,现代表普适性更强的递归缩写PHP: Hypertext Preprocessor。 - **用途**:一种广泛使用的开源通用脚本语言,尤其适合...

    主流日志监控软件技术选型分析.docx

    传统解决方案如grep、MySQL、NoSQL(如MongoDB)、Hadoop/Spark/Storm等各有优缺点,它们可能无法提供完整的日志管理和分析能力。例如,grep和MySQL在处理大量数据时效率较低,而NoSQL不支持复杂的交叉查询,Hadoop...

    ASP.NET的电子商务平台设计与实现.doc

    这些技术各有优缺点,但在实际应用中,ASP.NET因其独特的技术优势而备受青睐: - **代码清晰度**:ASP.NET提供了一种更为清晰简洁的代码编写方式,使得开发者能够更加专注于业务逻辑而非底层细节。 - **配置与可...

    Redis缓存数据库使用以及命令.docx

    Redis是一种高性能的键值对内存数据库,由意大利开发者Antonio意大利人Salatino于2009年创建,...同时,与NoSQL家族中的其他成员如MongoDB相比,Redis提供了独特的数据结构和操作命令,为开发人员提供了更多灵活性。

    CreateStaticHTML.rar

    同时,需要数据库连接来获取新闻数据,如MySQL、SQLite或MongoDB等。 6. **自动化流程**:项目可能包含一个脚本或服务,定时或在新闻更新时自动运行,将数据库中的新闻内容渲染成HTML页面,并保存到服务器的适当...

    常见的数据库类型.pptx

    关系型数据库,如MySQL、SQL Server、Oracle、Sybase、DB2和Access,基于关系模型,将数据以表格形式存储,每个表格由行和列组成,被称为表,多个表可以建立关联,形成数据库。这种数据库的主要优点包括: 1. **易...

    运维监控口碑排行榜.docx

    9. **天兔开源监控**:天兔专注于数据库监控,如MySQL、Oracle、MongoDB和Redis。它以简洁的界面和SQL语句级别的监控受到好评,但其监控范围有限,不适用于全面的系统监控。 这些工具各具特色,适应不同的运维场景...

    node.js

    在实际项目中,Node.js 常与其他技术结合使用,如前端框架 React、Vue 或 Angular,数据库 MongoDB、MySQL 等,构建全栈式开发解决方案。同时,TypeScript 作为一种强类型的 JavaScript 超集,也被越来越多的 Node....

    基于Koa(nodejs框架)对json文件进行增删改查的示例代码

    在当前的IT领域中,使用Node.js框架开发Web应用程序变得越来越流行。Koa.js作为一个轻量级的Web...因此,当应用发展到需要更高性能和可靠性的阶段时,应考虑迁移到成熟的数据库系统,如MySQL、MongoDB或PostgreSQL等。

Global site tag (gtag.js) - Google Analytics