NoSQL,泛指非关系型的数据库。NoSQL数据库的产生就是为了解决大规模数据集合多重数据种类带来的挑战,尤其是大数据应用难题。
虽然关系型数据库系统RDBMS在安装和使用上仍然占有主要地位,但毋庸置疑,非关系型数据库NoSQL技术已经成为今天发展最快的数据库技术。
NoSQL详解:如何找到对的技术
NoSQL是对数据库系统的总称,在某种程度上,它的性能和用途可能完全不同。NoSQL一词最早产生于上世纪九十年代,意思是NoSQL(没有SQL语言),后来随着时间和技术的发展,SQL界面仍然作为处理数据的方式存在,所以NoSQL又有了新的诠释,即NotOnlySQL(不只是SQL语言)。今天,NoSQL数据库凭借着其非关系型、分布式、开源和横向扩展等优势,被认为是下一代数据库产品。
四种主要的NoSQL数据库和它们主要的应用场景
键值数据库:当数据以键的形式访问时,比如通过国际标准书号ISBN找一本书,键值数据库是最理想的。在这里,ISBN是键,书籍的其他信息就是值。必须知道键才能查询,不过值是一堆无意义的数据,读取之后必须经过翻译。
文档存储数据库:该数据库以文档的形式管理和存储数据。有点类似于键值数据库,但文档数据库中的数据有结构。与键值数据库中值是一堆无意义的数据不同,文档数据库中数据以文档的结构被描述,典型的是JavaScriptObjectNotation(JSON)或XML.文档存储数据库中的数据可以通过定义的任何模式进行查询,但键值数据库只能通过它的键进行查询。
列式数据库:也被称为列式存储或宽列存储,一改之前行式存储的方式,对数据进行列式存储。在传统关系型数据库中,数据经常以行来访问。以列式管理记录的NoSQL数据库可以管理大规模的动态列。因为没有固定的模式,所以列名和键可以变换。列式数据库适用于不经常写的情况,要满足ACID(原子性、一致性、隔离性和持久性)的要求并不难,而且模式是变化的。
图型数据库:图型数据库关注值与值之间的关系,用图型的数学概念存储数据。图型数据库用带有点、边缘和属性的图的结构表示和存储数据。在图型数据库中,每一个元素都包含一个直接的指向它毗邻元素的点,所以也就不需要索引查找。
NoSQL数据库在网页扩展、大数据和分析部署等方面越来越流行。每一个种类的NoSQL数据库都有适用的不同类型的应用程序和用例,这就涉及到一个NoSQL社区常用的一个话题,即多样持久性,或者说根据数据库处理应用程序需求的不同,使用不同的数据库系统,用于不同的应用程序和用例。
因此,使用NoSQL最重要的是使用正确的数据库,满足具体的需求,哪怕是要引入一种新的数据库系统。
NoSQL的优势和劣势
那么,为什么考虑用NoSQL数据库替代传统数据库呢?也许,前者最大的有点在于它的去中心化、可扩展、容错能力等属性。很多公司应用NoSQL数据库技术是考虑了它的可扩展能力。
用NoSQL数据库,你可以为每一个特殊的用例定制化你的数据管理解决方案。关系型数据库可以通过不同的用例广泛地应用于实践。通过考虑多样持久性,组织可以选择最能适应特殊应用场景的数据库技术。
另外,大多数NoSQL产品都是轻量级的,因此花费比较少。自从NoSQL产品被设计用来满足特殊的用例和解决特殊的问题,它的功能也就比大多数关系型数据库少,因为后者要应用于更广泛的领域。因此,NoSQL数据库需要的代码更少,这也是和复杂的关系型数据库相比具备的一项优势。
当然,NoSQL也有它的缺点。ACID协议是关系型数据库的标准,但很多NoSQL数据库做不到。如果ACID支持很关键,你必须要确定你选的NoSQL数据库是否提供ACID。
六大考虑因素
NoSQL数据库之间的很多不同给技术选择带来了难度。不同的数据库类型和产品有不同的架构。即使同样是NoSQL数据库,不同类型之间也有所不同,没有统一标准,即便是访问数据的标准也不相同。这意味着在不同的数据库中访问数据,有不同的工具和应用程序需要采用和学习。以下是需要考虑的一些方面。
快速变化
NoSQL领域是持续变动的,特性不断提升、功能不断增加、甚至会产生新产品。在选择NoSQL数据库时,很难跟上最新最好的功能和产品。
对ACID的支持能力越来越强
NoSQL的一个早期卖点是它支持不要求全部ACID支持的事务。取代ACID,NoSQL提升了最终一致的基本可用软件状态服务(BASE)。虽然如此,很多应用程序依然依赖ACID,NoSQL对ACID事务的支持是用户的需求,也是它自己在不断完善的。
缺少对多平台的支持
大多数NoSQL数据库起源于开源运动,因此基本上都运行在Linux上,(或者Unix的变体)。如果你需要在Windows或者主机上部署数据库,你需要考虑商业产品,因为商业产品对多平台部署的支持性更好。
增加对SQL的支持
没有SQL,查询通常非常基础,可能要求使用高级语言的复杂的代码。当然,产品与产品之间也有所不同,不过最好选择支持SQL的NoSQL数据库,因为很多开发者熟悉的还是SQL语言。
开发多种类型数据库的能力
一些NoSQL数据库允许你用键值对、文档和图型的弹性的组合建模和部署数据。另外,关系型数据库开始采用NoSQL能力。使用能够开发多种类型数据库存储的数据库系统能帮助你的组织获得普适的持久性。
注意技术的版本。很多开源项目运行了很多年,但也没有第一版。这些软件可能很好用,但慎重的公司一般不会选择没有发行第一版的技术。
NoSQL数据库的另一个缺点是不支持SQL语言。经过40多年的发展,SQL已经成为访问数据的通用语言。一套数据库系统不支持SQL语言就意味着要求开发者学习不同的访问数据的语言。不过,像有的NoSQL支持ACID一样,有的NoSQL数据库也支持SQL语言,但不像传统关系型数据库那样全面。总之,想要不做重大更改就在NoSQL数据库中运行SQL查询是不可能的。
今天的NoSQL市场依然很混乱。严格来讲,有上百种不同的NoSQL数据库可供选择。而且没有像关系型数据库一样正规的数据模型,因此NoSQL数据库之间也是各不相同的,即便是同一种类也有所不同。这种混乱给NoSQL的广泛应用带来了阻碍,如果没有深度的投资和研发,它很难成功。
虽然NoSQL数据库现在发展的很火,但该领域仍然面临激烈竞争,日新月异。真正理解NoSQL数据局,需要深入了解不同数据库引擎及其用例。选择了错误的技术很可能导致整个项目的失败。
今天,有很多NoSQL数据库系统得到了成功的应用,一旦应用到正确的地方,它将发挥出无穷的力量。
¥798.00
¥199.00
¥48.00¥180.00
¥48.00¥180.00
¥29.90
¥199.00