粉碎5个NoSQL流言:各司其职,NoSQL的出现比关系型更早

转载 2013年12月06日 10:12:19
摘要:任何事物在大肆宣传下都会被蒙上一些夸张、不切实际的光环,NoSQL运动同样如此,本文将揭穿一些广被认同并影响深远的流言。

巴西人Henrique Lobo Weissmann(还有个名字叫Kico Lobo)是咨询公司itexto的联合创始人,他还在2008年创立了Grails Brasil——巴西最大的Groovy and Grails 用户组织,当下成员已超过1700个,仍处于飞速增长阶段。近日Kico在其博客上发表了多篇NoSQL精彩博文,这里为大家分享他对NoSQL一些常见宣传的看法。以下为译文:

与许多流行词一样,NoSQL在大肆宣传后,许多荒谬的观点产生,本篇文章将揭穿其中广被认同的5个。

流言1:NoSQL是新鲜事物

从根本上说,NoSQL数据库系统的几大属性都不是出于关系模型,而关系模型首次揭露是在1970年 Codd发布的文章中。

那么,这是否就意味着在1970年之前不存在任何其它的数据库系统?不容争论的是,这些数据库却是真实存在,比如CODASYL系统,它显然不是关系型数据库;基于其主要属性,NoSQL的诞生其实明显早于传统关系型数据库。

流言2:遗弃数据结构模型

从长远上看,这个流言的影响更为恶劣。虽然许多NoSQL解决方案都不会强迫你使用严格的数据结构模型,但是绝对不意味它可以忽视。而在实际操作中也是恰恰相反的,随着时间的流逝,你必须明白你为什么要使用这些属性。

有些情况可能会更加危险,举个MongoDB的例子:作为一个良好的实践,许多经验丰富的用户都会建议去建立文档的属性,在文档大小改变时,通过预分配大小去避免文档的完整拷贝。还有在查询优化时,你必须要清楚你的结构模型以便做索引。

流言3:NoSQL的扩展性永远都是卓越的

高扩展性是NoSQL的主要卖点之一,但是仅仅选择一个NoSQL解决方案并不意味着扩展性问题的解决,真正解决问题的是优秀的架构。

不错,这里确实存在通过选择NoSQL让系统扩展性得到了大幅度的提升。然而胜利的背后依稀可见的是数据结构的变化,在特定场景下使用正确的结构替换错的。

这个流言中有趣的地方是忽略了同样提供优秀扩展性的关系型数据库,不错,使用NoSQL方案进行扩展确实非常容易,但是NoSQL的选择绝对不是问题解决的唯一功臣。

流言4:不公平的基准

你如何才能公平的比较两个完全不同的持久化方案,比如:键值、关系、文档等等。而当下许多NoSQL与关系型数据库的对比也并不公平。

当你的查询只涉及一个键时,NoSQL数据库的性能明显要优于关系型数据库。公平的基准应该建立在同类型产品的比较之上,类似MySQL与MongoDB的对比根本无任何意义。即使系统性能取得了巨大提升,也只是开始时使用了错误的数据结构模型而已。

流言5:NoSQL可以大幅度的提高生产力

这一点只发生在梦中,或者是开始选择了错误的工具。在选择NoSQL之前,我们已经使用了多年的关系型数据库,这里只存在团队花大量精力去适应NoSQL的情况。

很少人谈及这一点, NoSQL采用最大的挑战是文化,而不是技术。新事物之所以难以接受,是因为“老伙计”用起来很舒服,即使新事物更加得优秀。生产力源于实践,而不是魔术。

总结

对比近年来研发领域发生的事件,NoSQL绝对可以称得上最有意义之一;然而需要铭记的是,任何提升都需要付出同等的代价。

原文链接: Some myths about NoSQL (编译/仲浩 审校/王鹏)

转自:
http://www.csdn.net/article/2013-09-05/2816840-some-myths-about-nosql 


相关文章推荐

5.非关系型数据库(Nosql)之mongodb:创建集合,备份与导入导出, 数据还原,导入导出

1 固定集合 固定集合值得是事先创建而且大小固定的集合 2 固定集合的特征:固定集合很像环形队列,如果空间不足,最早文档就会被删除,为新的文档腾出空间。一般来说,固定集合适用于任何想要自动淘汰过期...

关系型数据库和nosql数据库的区别和选择

关系型数据库和nosql数据库有着不同的用途。 我们常常把这些不同类型的数据库用在错误的地方。 最常见的是在关系数据库内保存大量非计算的数据。 像日志啊,账号啊,这些仅仅只是需要查询的数据都放在...

Nosql笔记(一)——关系型数据库回顾

Nosql笔记(一)——关系型数据库回顾            在平常的商业应用中,我们所使用的大多都是关系型数据库,诸如SQL  Server、 MY SQL、 Oracle等。 关于关系型数据库中...

谈谈NoSQL——非关系型数据库概览

NoSql前言随着大数据时代的崛起,应用程序需要处理的数据的复杂性大大增加,数据的复杂性不仅包括它的大小,还包括它的相互关联性,结构的千变万化以及对数据的同时访问。 假设,我们要查询一组数据,但是j...

关系型数据库nosql redis初学

redis安装过程解压压缩包tar zxf redis-3.0.2.tar.gz然后进入解压目录中make && make install #确保安装了gcc然后进入utils目录cd utils/ ...

【NOSQL】非关系型数据库MongoDB ( MongoDB索引用法和效率分析 )

MongoDB中的索引其实类似于关系型数据库,都是为了提高查询和排序的效率的,并且实现原理也基本一致。由于集合中的键(字段)可以是普通数据类型,也可以是子文档。MongoDB可以在各种类型的键上创建索...

【NOSQL】非关系型数据库MongoDB ( 在MVC模式下通过Jqgrid表格操作MongoDB数据 ) .

看到下图,是通过Jqgrid实现表格数据的基本增删查改的操作。表格数据增删改是一般企业应用系统开发的常见功能,不过不同的是这个表格数据来源是非关系型的数据库MongoDB。nosql虽然概念新颖,但是...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:粉碎5个NoSQL流言:各司其职,NoSQL的出现比关系型更早
举报原因:
原因补充:

(最多只允许输入30个字)