NoSQL,指的是非关系型的数据库。NoSQL有时也称做Not Only SQL的缩写,是对不一样于传统的关系型数据库的数据库管理系统的统称,它具备非关系型、分布式、不提供ACID的数据库设计模式等特征。java
NoSQL用于超大规模数据的存储。(例如谷歌或Facebook天天为他们的用户收集万亿比特的数据)。这些类型的数据存储不须要固定的模式,无需多余操做就能够横向扩展。面试
SQL数据库适合那些需求肯定和对数据完整性要去严格的项目。NoSQL数据库适用于那些对速度和可扩展性比较看重的那些不相关的,不肯定和不断发展的需求。简单来讲就是:算法
SQL是精确的。它最适合于具备精确标准的定义明确的项目。典型的使用场景是在线商店和银行系统。sql
NoSQL是多变的。它最适合于具备不肯定需求的数据。典型的使用场景是社交网络,客户管理和网络分析系统。数据库
1.关系型数据库和非关系型数据库设计模式
SQL (Structured Query Language) 数据库,指关系型数据库。主要表明:SQL Server,Oracle,MySQL等。缓存
NoSQL(Not Only SQL)泛指非关系型数据库,主要表明:MongoDB,Redis等。网络
2.关系型数据库适合存储结构化数据数据结构
如用户的账号、地址等:架构
1)这些数据一般须要作结构化查询,好比join,这时候,关系型数据库就要胜出一筹
2)这些数据的规模、增加的速度一般是能够预期的
3)保证数据的事务性、一致性要求。
3.NoSQL适合存储非结构化数据
如发微博、文章、评论:
1)这些数据一般用于模糊处理,如全文搜索、机器学习
2)这些数据是海量的,并且增加的速度是难以预期的,
3)根据数据的特色,NoSQL数据库一般具备无限(至少接近)伸缩性
4)按key获取数据效率很高,可是对join或其余结构化查询的支持就比较差
目前许多大型互联网项目都会选用MySQL(或任何关系型数据库) + NoSQL的组合方案。
有四种常见的 NoSQL 数据库类型:列式、文档、图形和内存键值。
1.列式数据
顾名思义,是按列存储数据的。最大的特色是方便存储结构化和半结构化数据,方便作数据压缩,对针对某一列或者某几列的查询有很是大的IO优点。
1)对应的nosql: HBase,BigTable等。
2)典型应用场景:按列存储,针对某一列或者某几列的查询有很是大的IO优点。
3)优势:查找速度快,可扩展性强,更容易进行分布式扩展。
4)缺点:功能相对局限。
2.文档数据库
旨在将半结构化数据存储为文档,一般采用 JSON 或 XML 格式。与传统关系数据库不一样的是,每一个 NoSQL 文档的架构是不一样的,可以让您更加灵活地整理和存储应用程序数据并减小可选值所需的存储。
1)对应的nosql:CouchDB, MongoDb
2)典型应用场景:存储相似JSON格式的内容,可对某些字段创建索引功能,是最像关系型的数据库。
3)优势:数据结构要求不严格,表结构可变,不须要像关系型数据库同样须要预先定义表结构。
4)缺点:查询性能不高,并且缺少统一的查询语法。
3.图形数据库
可存储顶点以及称为边缘的直接链路。图形数据库能够在 SQL 和 NoSQL 数据库上构建。顶点和边缘能够拥有各自的相关属性。
1)数据模型:图结构
2)典型应用场景:社交网络,推荐系统等。专一于构建关系图谱,善于处理大量复杂、互链接、低结构化的数据,数据每每变化迅速,且查询频繁。
3)优势:利用图结构相关算法。好比最短路径寻址,N度关系查找等。
4)缺点:不少时候须要对整个图作计算才能得出须要的信息,并且这种结构不太好作分布式的集群方案。
4.内存键值存储
能够经过key快速查询到其value。通常来讲,存储无论value的格式,照单全收,是针对读取密集型应用程序工做负载(例如社交网络、游戏、媒体共享和 Q&A 门户)。内存缓存可将重要数据存储在内存中以实现低延迟访问,从而提升应用程序性能。
1)对应的nosql:Redis,Memcached等
2)典型应用场景:内容缓存,主要用于处理大量数据的高访问负载,也用于一些日志系统等等。
3)优势:查找速度快。
4)缺点:数据无结构化,一般只被看成字符串或者二进制数据。
若是对java微服务、分布式、高并发、高可用、大型互联网架构技术、面试经验交流。
能够加我架构圈子群:692-845-439 领取资料,群内天天更新资料,免费领取。