NoSQL与关系型数据库

一、NoSQL
NoSQL的全称是Not Only SQL,这个概念早就有人提出,在09年的时候比较火。NoSQL指的是非关系型数据库,而我们常用的都是关系型数据库。就像我们常用的MySQL、SqlServer一样,这些数据库一般用来存储重要信息,应对普通的业务是没有问题的。但是,随着互联网的高速发展,传统的关系型数据库在应付超大规模、超大流量以及高并发的时候力不从心。而就在这个时候,NoSQL得到了高速的发展。

二、NoSQL和关系型数据库的区别
1.存储方式
关系型数据库是表格式的,因此存储在表的行和列中。它们之间很容易关联协作存储,提取数据很方便。而NoSQL数据库则与其相反,它是大块地组合在一起,通常存储在数据集中,就像文档、键值对或图结构。

2.存储结构
关系型数据库对应的是结构化数据,数据表都预先定义了结构(列的定义),结构描述了数据的形式和内容。这一点对数据建模至关重要,虽然预定义结构带来了可靠性和稳定性,但是修改这些数据比较困难。而NoSQL数据库基于动态结构,使用非结构化数据。因为NoSQL数据库是动态结构,可以很容易适应数据类型和结构的变化。

3.存储规范
关系型数据库的数据存储为了更高的规范性,把数据分割为最小的关系表以避免重复,获得精简的空间利用。虽然管理起来很清晰,但是单个操作设计到多张表的时候,数据管理就显得有点麻烦。而NoSQL数据存储在平面数据集中,数据经常可能会重复,单个数据库很少被分割开,而是存储在一个整体,这样整块数据更便于读写。

4.存储扩展
这可能是两者之间最大的区别,关系型数据库是纵向扩展,也就是说,要想提高处理能力,就使用速度更快的计算机。因为数据存储在关系表中,操作的性能瓶颈可能涉及到多个表,需要通过提升计算机性能来克服。虽然有很大的扩展空间,但是最终会达到纵向扩展的上限。而NoSQL数据库是横向扩展的,它的存储天然就是分布式的,可以通过给资源池添加更多的普通数据库服务器来分担负载。

5.查询方式
关系型数据库通过结构化查询语句来操作数据库(就是我们通常说的SQL)。SQL支持数据库CURD操作的功能非常强大,是业界的标准用法。而NoSQL查询以块为单元操作数据,使用的是非结构化查询语言(UnQI),它是没有标准的。关系型数据库表中主键的概念对应NoSQL中存储文档的ID。关系型数据库使用预定义优化方式(比如索引)来加快查询操作,而NoSQL有更简单更精确的数据访问模式。

6.事务
关系型数据库遵循ACID规则(原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)),而NoSQL数据库遵循BASE原则(基本可用(Basically Availble)、软/柔性事务(Soft-state)、最终一致性(Eventual Consistency))。由于关系型数据库的强一致性,所以对事务支持得很好。关系型数据库支持对事务原子性细粒度控制,并且易于回滚事务。而NoSQL数据库是在CAP(一致性、可用性、分区容忍性)中任选两项,因为基于节点的分布式系统中,很难全部满足,所以对事务的支持不是很好,虽然也可以使用事务,但这并不是NoSQL的闪光点。

7.性能
关系型数据库为了维护数据的一致性付出了巨大的代价,读写性能比较差。在面对高并发时读写性能非常差,面对海量数据时效率非常低。而NoSQL的存储格式都是Key-Value类型的,并且存储在内存中,非常容易存储,而且对于数据的一致性是弱要求,NoSQL无需SQL的解析,提高了读写的性能。

8.授权方式
关系型数据库通常有SqlServer、MySQL、Oracle。主流的NoSQL数据库有Redis、Memcached、MongoDB。大多数关系型数据库都是付费的并且价格昂贵,成本较大,而NoSQL数据库通常都是开源的。

转载于:https://www.cnblogs.com/yuanfei1110111/p/10623959.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值