MySQL
|
MongoDB
|
解释
|
Database
|
database
|
数据库
|
Table
|
collection
|
数据表/集合
|
Row【一条记录,实体】
|
document
|
行/文档
|
Column
|
field
|
列/字段或属性
|
table join
|
不支持
|
表连接
|
Primary key
|
primary key
|
主键
|
分类
|
举例
|
典型应用场景
|
键值数据库
|
Redis
|
缓存,主要用于处理大量数据的高访问负载。
|
列族数据库
|
HBase
|
海量数据的分布式存储
|
文档型数据库
|
MongoDB
|
Web 应用的数据存储
|
图形数据库
|
Neo4J
|
社交网络,推荐系统等。专注于构建关系图谱
|
关系型数据库是表格式的,因此存储在表的行和列中。他们之间很容易关联协作存储,提取数据很方便。而Nosql数据库则与其相反,他是大块的组合在一起。通常存储在数据集中,就像文档、键值对或者图结构。
关系型数据库对应的是结构化数据,数据表都预先定义了结构(列的定义),结构描述了数据的形式和内容。这一点对数据建模至关重要,虽然预定义结构带来了可靠性和稳定性,但是修改这些数据比较困难。而Nosql数据库基于动态结构,使用与非结构化数据。因为Nosql数据库是动态结构,可以很容易适应数据类型和结构的变化。
关系型数据库的数据存储为了更高的规范性,把数据分割为最小的关系表以避免重复,获得精简的空间利用。虽然管理起来很清晰,但是单个操作设计到多张表的时候,数据管理就显得有点麻烦。而Nosql数据存储在平面数据集中,数据经常可能会重复。单个数据库很少被分隔开,而是存储成了一个整体,这样整块数据更加便于读写
这可能是两者之间最大的区别,关系型数据库是纵向扩展,也就是说想要提高处理能力,要使用速度更快的计算机。因为数据存储在关系表中,操作的性能瓶颈可能涉及到多个表,需要通过提升计算机性能来克服。虽然有很大的扩展空间,但是最终会达到纵向扩展的上限。而Nosql数据库是横向扩展的,它的存储天然就是分布式的,可以通过给资源池添加更多的普通数据库服务器来分担负载。
关系型数据库通过结构化查询语言来操作数据库(就是我们通常说的SQL)。SQL支持数据库CURD操作的功能非常强大,是业界的标准用法。而Nosql查询以块为单元操作数据,使用的是非结构化查询语言(UnQl),它是没有标准的。关系型数据库表中主键的概念对应Nosql中存储文档的ID。关系型数据库使用预定义优化方式(比如索引)来加快查询操作,而Nosql更简单更精确的数据访问模式。
分类
|
举例
|
典型应用场景
|
数据模型
|
优点
|
缺点
|
键值 数据 库
|
Redis
|
缓存,主要用于处理大量数据的高访问负载。
|
Key - Value 键值对,通常用hash table来实现
|
查找速度快
|
数据无结构化,通常只被当作字符串或者二进制数 据
|
列族数据库
|
HBase
|
海量数据的分布式存储
|
以列族存储,将同一列族数据存在一起
|
容量巨大、高可靠性、高可扩展性
|
功能相对局限
|
文档型数据库
|
MongoD B
|
Web应用的数据存储
|
Json 文档,也可以说是Key-Value键值对
|
数据结构要求不严格,不需要像关系型数据库一样需要预先定义表结构
|
查询性能不高,而且缺乏统一的查询语法。
|
图形数据库
|
Neo4J
|
社交网络,推荐系统等。专注于构建关系图谱
|
图结构
|
利用图结构相关算法。比如最短路径寻址等
|
很多时候需要对整个图做计算才能得出需要的信息,
不好做分布式的集群方案。
|