一、What's NoSQL?

NoSQL,全称是”Not Only Sql”,指的是非关系型的数据库。这类数据库主要有这些特点:非关系型的、分布式的、开源的、水平可扩展的。原始的目的是为了大规模web 应用。NoSQL 的拥护者们提倡运用非关系型的数据存储,通常的应用如:模式自由、支持简易复制、简单的API、最终的一致性(非ACID)、大容量数据等。NoSQL 被我们用得最多的当数key-value 存储,当然还有其他的文档型的、列存储、图型数据库、xml 数据库等。

二、Why NoSQL?

随着互联网web2.0 网站的兴起,非关系型的数据库现在成了一个极其热门的新领域,非关系数据库产品的发展非常迅速,而传统的关系型数据库在应付web2.0 网站,特别是超大规模和高并发的SNS 类型的web2.0 纯动态网站已经显得力不从心,暴露了很多难以克服的问题,例如:

  1. High performance - 对数据库高并发读写的需求web2.0 网站要根据用户个性化信息来实时生成动态页面和提供动态信息,所以基本上无法使用动态页面静态化技术,因此数据库并发负载非常高,往往要达到每秒上万次读写请求。关系型数据库应付上万次SQL 查询还勉强顶得住,但是应付上万次SQL 写数据请求,硬盘IO 就已经无法承受了,其实对于普通的BBS 网站,往往也存在对高并发写请求的需求。
  2. Huge Storage - 对海量数据的高效率存储和访问的需求对于大型的SNS 网站,每天用户产生海量的用户动态信息,对于关系数据库来说,在一张上亿条记录的表里面进行SQL 查询,效率是极其低下乃至不可忍受的。
  3. High Scalability && High Availability - 对数据库的高可扩展性和高可用性的需求在基于web 的架构当中,数据库是最难进行横向扩展的,当一个应用系统的用户量和访问量与日俱增的时候,你的数据库却没有办法像web server 和app server 那样简单的通过添加更多的硬件和服务节点来扩展性能和负载能力。对于很多需要提供24 小时不间断服务的网站来说,对数据库系统进行升级和扩展是非常痛苦的事情,往往需要停机维护和数据迁移,可是停机维护随之带来的就是公司收入的减少。

在上面提到的“三高”需求面前,关系数据库遇到了难以克服的障碍,而对于web2.0 网站来说,关系数据库的很多主要特性却往往无用武之地,例如:

  1. 数据库事务一致性需求很多web 实时系统并不要求严格的数据库事务,对读一致性的要求很低,有些场合对写一致性要求也不高。因此数据库事务管理成了数据库高负载下一个沉重的负担。
  2. 数据库的写实时性和读实时性需求对关系数据库来说,插入一条数据之后立刻查询,是肯定可以读出来这条数据的,但是对于很多web 应用来说,并不要求这么高的实时性。
  3. 复杂的SQL查询,特别是多表关联查询的需求任何大数据量的web 系统,都非常忌讳多个大表的关联查询,以及复杂的数据分析类型的复杂SQL 报表查询,特别是SNS 类型的网站,从需求以及产品设计角度,就避免了这种情况的产生。往往更多的只是单表的主键查询,以及单表的简单条件分页查询,SQL 的功能被极大的弱化了。

因此,关系数据库在这些越来越多的应用场景下显得不那么合适了,为了解决这类问题的NoSQL 数据库应运而生。

三、NoSQL Features

  1. 它可以处理超大量的数据
  2. 它运行在便宜的PC服务器集群上PC 集群扩充起来非常方便并且成本很低,避免了传统商业数据库“sharding”操作的复杂性和成本。
  3. 它击碎了性能瓶颈NoSQL 的支持者称,通过NoSQL 架构可以省去将Web 或Java 应用和数据转换成SQL 格式的时间,执行速度变得更快。“SQL 并非适用于所有的程序代码”,对于那些繁重的重复操作的数据,SQL 值得花钱。但是当数据库结构非常简单时,SQL 可能没有太大用处。
  4. 它没有过多的操作虽然NoSQL 的支持者也承认关系型数据库提供了无可比拟的功能集合,而且在数据完整性上也发挥绝对稳定,他们同时也表示,企业的具体需求可能没有那么复杂。
  5. 它的支持者源于社区因为NoSQL 项目都是开源的,因此它们缺乏供应商提供的正式支持。这一点它们与大多数开源项目一样,不得不从社区中寻求支持。

相关文章: NoSQL数据库探讨之一 - 为什么要用非关系数据库?   Nosql入门知识   MongoDB(NoSQL) 入门   NoSQL入门文章推荐   

      NoSQL介绍及MongoDB入门

转载于:https://www.cnblogs.com/WayneZeng/p/3310251.html

NoSQL数据库--简介相关推荐

  1. 【Redis6快速深入学习01】NoSQL数据库简介

    文章目录 1 NoSQL数据库简介 1.1 技术发展 1.2 NoSQL数据库 1.3 行式存储数据库(大数据时代) 1.4 图关系型数据库 1 NoSQL数据库简介 1.1 技术发展 技术的分类 解 ...

  2. [Redis6]NoSQL数据库简介_特点

    NoSQL数据库简介 NoSQL(NoSQL = Not Only SQL ),意即"不仅仅是SQL",泛指非关系型的数据库. NoSQL 不依赖业务逻辑方式存储,而以简单的key ...

  3. NoSQL 数据库 简介

    一.  NoSQL概念 开源的数据库用的最多的是PostgreSQL和MySQL. 关于这2者的对比,参考我的Blog: MySQL 和 PostgreSQL 对比 http://blog.csdn. ...

  4. NoSql数据库简介及Redis学习

    NO-Sql数据库:Not Only不仅仅是SQL 定义:非关系型数据库:NoSQL用于超大规模数据的存储.(例如谷歌或Facebook每天为他们的用户收集万亿比特的数据).这些类型的数据存储不需要固 ...

  5. NoSql 数据库简介

    [一]技术发展 技术的分类 1. 解决功能性的问题: Java . Jsp . RDBMS . Tomcat . HTML . Linux . JDBC . SVN 我们做一个项目,无外乎增删改查操作 ...

  6. 1.NoSQL数据库简介

    1.1技术发展 技术的分类 1.解决功能性的问题:Java.Jsp.RDBMS.Tomcat.HTML.Linux.JDBC.SVN 2.解决扩展性的问题:Struts.Spring.SpringMV ...

  7. 【用户画像】功能实现值写入ClickHouse人群包、预估和更新分群人数,NoSQL数据库介绍

    文章目录 一 写入ClickHouse人群包 1 组合查询Bitmap表SQL代码实现 (1)SQL语句分析 (2)实现思路 (3)实现过程 controller层 service层 Taginfo实 ...

  8. NoSQL数据库Redis使用命令简介

    NoSQL 数据库Redis使用命令简介 NOSQL数据库可以按照它们的数据模型分成4类: 1.键-值对存储库(Key-Value) redis-- 2.BigTable实现(BigTable-imp ...

  9. 【简介】分布式NoSQL数据库

    分布式NoSQL数据库 基本概念 什么是NoSQL? NoSQL是一些分布式非关系型数据库的统称,它采用非关系的数据模型,弱化模式或表结构.弱化完整性约束.弱化甚至取消事务机制,可能无法支持,或不能完 ...

最新文章

  1. 简述WSL 2安装和WSL 1转换为WSL 2
  2. GitHub超4.4k星:程序员求职,一个算法模板就够了
  3. linux git 推送空文件夹
  4. sentinel 时间窗口_Sentinel潜龙勿用篇
  5. 【操作系统】页置换算法
  6. python第三方模块安装路径_Python第三方Window模块文件的几种安装方法
  7. 新的博客,试试写博客看看
  8. AngularJs的TDD
  9. Delphi--“Range check error“ 错误解决方案之一
  10. Java程序员每天的工作都是做什么的?
  11. PSM模型(价格敏感测试模型)
  12. html绘图插件,canvas,svg,vml绘图插件
  13. mac上利用openssl命令进行软件安装包的哈希校验
  14. Google SEO和SEM的不同之处?
  15. 【金融风控】信用评分卡模型
  16. 腾讯云主机Ubuntu之服务器环境搭建以及宝塔面板安装
  17. UE4 Gameplay框架浅析笔记
  18. 高斯整数 / 费马平方和定理 / 拉格朗日的四平方定理
  19. 手机上的计算机黑屏怎么办,手机黑屏是怎么回事,详细教您苹果手机黑屏怎么办...
  20. base64常用的前缀(excel,doc,pdf,png,jpg)

热门文章

  1. Ansible 入门:安装 简例 playbook应用
  2. 【Linux】Linux 标准目录结构
  3. Java探索之旅(2)——GUI输入输出与代码的规范性
  4. Unity学习笔记:unity介绍(一)
  5. mac安装homebrew_Homebrew简介:在Mac上轻松安装任何东西的简便方法
  6. wpf开源ui引用步骤_如何通过7个步骤开源您的学术作品
  7. 代码重用_WebAssembly的速度和代码重用
  8. 开源压缩算法brotli_Brotli:一种新的压缩算法,可加快互联网速度
  9. linksys 打印软件_Linksys对FCC表示“不”,Mozilla扩大了开源资金,还有更多新闻
  10. 物联网linux_Linux的未来,Google的物联网标准等