SQL作为主要的数据存储方式已经超过40年,并且经历了至少两个指数扩张期:20世纪90年代Web应用程序崛起之后,以及在过去十年中由于移动设备爆炸引起的扩张。

因此,越来越小的公司开始发现使用数据库的好处,而像Google这样的互联网巨头则已经将数据单位上升到PB或甚至EB。

在 SQL 的发展过程中,产生了许多迭代产品,其中最重要的是SQL,NoSQL和NewSQL — 它们一起负责绝大部分的数据库市场。关注微信公众号:互联网架构师,在后台回复:2T,可以获取我整理的教程,都是干货。

所以,如果你要选择一个数据库工具,你应该选择哪一个?其实,没有明确的答案。不同的人和公司选择不同,这更多地取决于他们对每个特定项目的偏好和相对优势,而不是其中一个对其他所有的直接优势。那么,这些优点和缺点是什么?让我们来看一下。

SQL

SQL是关系型数据库管理系统(RDBMS),顾名思义,它是围绕关系代数和元组关系演算构建的。

70年代以来,它一直是主要的数据库解决方案,只是最近才有了其他产品的空间。不管有些人说什么,这意味着它一直能出色地执行广泛的任务。

其主要优点如下:

  • 不同的角色(开发者,用户,数据库管理员)使用相同的语言。

  • 不同的RDBMS使用统一标准的语言。

  • SQL使用一种高级的非结构化查询语言。

  • 它坚持 ACID 准则 (原子性,一致性,隔离性,持久性),,这些准则保证了数据库尤其是每个事务的稳定性,安全性和可预测性。

如你所见,许多SQL的好处来源于它的统一性,舒适性和易用性。即使你只有非常有限的SQL知识(或完全没有,如果需要),你可以在像 online SQL Query Builder 这样的特殊工具帮助下使用它。

然而,它的缺点使得它非常不适合某些类型的项目。SQL的主要问题是它难以扩展,因为它的性能随着数据库的变大而快速下降。分布式也是有问题的。

NoSQL和NewSQL出现的原因之一是,以前的RDBMS的设计不能满足现代数据库每秒处理的事务数量。像亚马逊或阿里巴巴等需要处理惊人数据量的巨头,以前的RDBMS会在几分钟内出现问题。

NoSQL (Not Only SQL)

NoSQL越来越受欢迎,其中最重要的实现是Apache Cassandra,MongoDB等产品。它主要用于解决SQL的可扩展性问题。因此,它是没有架构的并且建立在分布式系统上,这使得它易于扩展和分片。

然而,这些好处是以放宽ACID原则为代价的:NoSQL采取最终一致性原则,而不是所有四个参数在每个事务中保持一致。这意味着如果在特定时间段内没有特定数据项的更新,则最终对其所有的访问都将返回最后更新的值。这就是这样的系统通常被描述为提供基本保证的原因(基本可用,软状态,最终一致性) — 而不是ACID。

虽然这个方案极大地增加了可用时间和伸缩性,它也会导致数据丢失----这个问题的严重程度取决于数据库服务器的支持情况和应用代码质量.在某些情况下,这个问题十分严重.

另一个NoSQL出现的问题是现在有很多类型的NoSQL系统,但它们之间却几乎没有一致性.诸如灵活性,性能,复杂性,伸缩性等等特性在不同系统间差别巨大,这使得甚至是专家在他们之间都很难选择.不过,当你根据项目特点作出了合适的选择,NoSQL可以在不显著丢失稳定性的情况下提供一个远比SQL系统更高效的解决方案.

NewSQL

NewSQL是一种相对较新的形式,旨在使用现有的编程语言和以前不可用的技术来结合SQL和NoSQL中最好的部分。NewSQL目标是将SQL的ACID保证与NoSQL的可扩展性和高性能相结合。

显然,因为结合了过去仅单独存在的优点,NewSQL看起来很有前途; 或许,在未来的某个时候,它将成为大多数人使用的标准。不幸的是,目前大多数NewSQL数据库都是专有软件或仅适用于特定场景,这显然限制了新技术的普及和应用。

除此之外,NewSQL在每个方面比较均匀,每个解决方案都有自己的缺点和优势。

例如,SAP HANA可以轻松处理低到中等的事务性工作负载,但不使用本机集群,MemSQL对于集群分析很有用,但在ACID事务上表现出较差的一致性,等等。因此,在这些解决方案变得真正普及之前,可能还需要一段时间。

结论

围绕SQL有许多谬见和误解:例如,SQL已过时,应该尽可能替换为NoSQL或New SQL。当然,这不是真的。目前,在三种基本替代方案中没有明确的领导者 - 每一种都有更适合的项目,而在其他情况下不太适合(或完全不适合)。

因此,没有普遍的理想选择。例如,如果你主要考虑数据库应始终可用于接受新的内容,则应考虑最终一致性解决方案,如Cassandra或Riak。如果你追求高速缓存SQL,新的缓存数据库比如VoltDB似乎是明智的选择; 等等。

作者:hiekay
https://www.jianshu.com/p/ed55f20e736a

2T架构师学习资料干货分享

SQL、NoSQL 已过时,快升级到 NewSQL,长江后浪推进浪啊相关推荐

  1. 关于SQL+NoSQL : NewSQL数据库

    一.什么是数据库? 一般一个数据库系统(Database System)可分为两个部分: 数据库(Database) 数据管理系统(Database Management System,DBMS) A ...

  2. Java 8 Friday:大多数内部DSL已过时

    在Data Geekery ,我们喜欢Java. 而且,由于我们真的很喜欢jOOQ的流畅的API和查询DSL ,我们对Java 8将为我们的生态系统带来什么感到非常兴奋. Java 8星期五 每个星期 ...

  3. “此网站使用的安全性配置已过时,这可能会导致您的信息(例如密码、消息或信用卡卡号)”

    浏览器报错内容和截图: 您的连接存在安全隐患: 此网站使用的安全性配置已过时,这可能会导致您的信息(例如密码.消息或信用卡卡号) . 解决办法: 是将网站的TLS升级为安全的1.2

  4. IE错误 Java TM 已被阻止,因为它已过时并且需要更新 的解决方法

    自今年9月 10日,大量用户反馈,登陆到Oracle E-Business Suite后再点Form,IE 弹出"Java(TM)已被阻止,因为它已过时并且需要更新. "的错误,这 ...

  5. swing程序 过时拉嘛_密码已过时-如何保护您的应用程序和保护用户

    swing程序 过时拉嘛 重点 (Top highlight) I've said this part before, so if you read the previous article, ski ...

  6. 此网站使用的安全性配置已过时,这可能会导致您的信息(例如密码、消息或信用卡卡号)谷歌打不开https网站

    浏览器报错内容和截图: 您的连接存在安全隐患: 此网站使用的安全性配置已过时,这可能会导致您的信息(例如密码.消息或信用卡卡号) . 在这里插入图片描述 解决办法: 是将网站的TLS升级为安全的1.2 ...

  7. IDEA中提示:Warning:java: 源值1.5已过时, 将在未来所有发行版中删除

    问题描述: 运行Java Web项目时,IDEA中提示:Warning:java: 源值1.5已过时, 将在未来所有发行版中删除 解决方法: 1. 打开[File]-[Project Structur ...

  8. sql mysql 删除数据库_在sql中将已建数据库删除的详细步骤

    上期为大家讲解的建立数据库的方法,这期小编为大家讲解在sql中将已建数据库删除的详细步骤,一起去下文看看吧. 今天主要针对的是在SQL Server中已将建立好数据库之后呢!我们这边对建立完毕的数据库 ...

  9. 什么时候可以全面升级鸿蒙系统,华为已做好全面升级准备,鸿蒙系统将替换底层安卓系统...

    了解更多科技资讯尽在"圈聊科技". 今天跟大家聊一聊:鸿蒙传来新消息!华为已做好全面升级准备,将彻底替换底层安卓系统. 手机系统已经面临了多次的更新换代,在非智能时代的时候,诺基亚 ...

  10. C# “Thread类Suspend()与Resume()已过时” 解决方法(利用ManualResetEvent类)

    C# "Thread类Suspend()与Resume()已过时" 解决方法(利用ManualResetEvent类) 参考文章: (1)C# "Thread类Suspe ...

最新文章

  1. 通向人工智能产业落地化的道路在哪?
  2. SpringBoot优雅编码之:Lombok加持
  3. 酱油和gbt酱油哪个好_酱油不是越贵越好!找到这3个关键词,轻松避开勾兑酱油...
  4. golang跳转控制语句:goto语句示例
  5. Java 运算符、表达式、语句
  6. android动态设置文本居中显示图片,Android DrawableTextView图片文字居中显示实例
  7. proxmoxve打造云桌面_微软云电脑Cloud PC曝光:配置一般还不便宜
  8. 信息学奥赛一本通 1049:晶晶赴约会 | OpenJudge NOI 1.4 11
  9. python for android 安装配置_mac appium for android 环境搭建 (appium python pycharm)
  10. npu算力如何计算_华为云郑叶来:多元算力驱动应用创新
  11. 我做PM(项目经理)这段时间...
  12. L1-064 估值一亿的AI核心代码 (20 分)-PAT 团体程序设计天梯赛 GPLT
  13. 周博通 | 阿里开源首个 DL 框架、4000台服务器真实数据集;明年1月开源Blink...
  14. MVC模式在Java Web应用程序中的实现
  15. turnserver.conf文件详解
  16. ARM嵌入式的位绑定原理
  17. 游戏开发毛星云离世,他一直有个梦想:国产游戏能领跑世界
  18. 信息安全 SEED Lab10 Packet Sniffing and Spoofing Lab
  19. 微信支付快速生成签名sign
  20. MIT6.828课程JOS在macOS下的环境配置

热门文章

  1. 我国物联网发展如何跳出“窄巷”?
  2. 【兼容写法】HttpServerUtility.Execute 在等待异步操作完成时被阻止。关键词:MVC,分部视图,异步...
  3. 【ORACLE】ORA-12547: TNS:lost contact
  4. 「leetcode」486. 预测赢家:【三种递归+动态规划】由浅入深,步步到位
  5. 安装wordpress时候报错:Parse error: syntax error, unexpected '.', expecting '' or variable (T_VARIABLE)
  6. poj 2240 Arbitrage floyd基础,字符串输入有点麻烦
  7. Pr 入门教程,如何创建序列?
  8. 如何保持最佳 MacBook 温度?
  9. 为什么wait和notify必须在同步方法或同步块中调用?
  10. Spring Cloud Config服务器