首页 数据库 mysql教程 NoSQL的是与否

NoSQL的是与否

Jun 07, 2016 pm 04:44 PM
nosql oracle 数据库

随着大量数据的出现,NoSQL数据库架构正在被越来越多的人所使用,因为NoSQL架构对于大数据的处理上面更为有效。如今,当你需要存

To NoSQL or not toNoSQL

随着大量数据的出现,NoSQL数据库架构正在被越来越多的人所使用,因为NoSQL架构对于大数据的处理上面更为有效。

如今,当你需要存储和处理高容量的数据时,许多的年轻开发人员更倾向于选择开源的NoSQL。他们宣称NoSQL才是属于未来的数据库架构,甚至于一些硅谷的创业企业认为传统的关系型数据库已经没有存在的意义了。

与此同时,有经验的DBA和开发者却提出了一个值得注意的例子:由于NoSQL的弱点,黑客利用这些弱点成功进入了系统,导致了Flexcoin和Poloniex这两家比特币交易公司的失败。甚至还有坚持拥护RDBMS的人认为,NoSQL根本就不适合任何关键应用(missioncritical)的开发。

当然,事实的真相肯定就在这两极观点的中间,两种架构都有他们的独特特性和适合的场景,所以这两者应该是共存的。与其把特性发挥到极致,先专心处理实际应用所需的数据准确度显然更为有用,尤其是当不一致的数据遇到低容忍性的环境时。电子商务、金融、航运、物流和制造业都是这样的,对于这些产业,“最终一致性”并不能完全满足他们的需求,不一致的数据库可能会让业务变得很糟糕。

对于关键任务的开发,管理员需要即时的一致性而非“最终一致”,这才能保证数据可以立即使用并且在应用中保持一致,,而不需要等到应用的操作结束之后。为了能实现这种级别的安全防护,开发者需要数据库对于每个事务都具有ACID特性。最终一致性不能满足这些行业的需求,只有完全的ACID数据库才能解决,因为有ACID特性,每一个事务的操作才是可靠的、一致的,同时ACID特性也保重数据的一致性不会受到运行事故或者是外界干扰的影响。

而与此同时,一些流行的开源NoSQL数据库,如MongoDB和Cassandra,它们更容易搭建也可以很快的编写和部署应用。他们的快速也吸引了许多争分夺秒抢夺市场的公司。如今,这些数据库还提出了对应于ACID的新的概念BASE(基本可用性、软状态、最终一致)。

虽然流行的NoSQL数据库架构不都支持ACID的特性,一些NoSQL的集成实现却可以。这些集成实现甚至能实现关键性任务所需要的即时一致性的ACID特性。事实上,已经有一些金融服务企业正在采用具有即时一致性的NoSQL数据库,在严格管理的环境下来支持他们每秒数以百万计的金融事务。

有许多的在线零售商这样的商家,他们需要即时一致性的ACID支持,可是他们也需要能快速处理比如用户反馈一类的数据,这些数据不需要特别强的ACID支持,最终一致性就可以满足处理的需求了。

对于那些坚决使用NoSQL或者SQL的任何一方,不管怎么样,他们都要认识到SQL架构在金融应用中确实有它适合的场景,比如分析一个标准格式的报表。

所以,对于需要短时间处理大量的数据、拓展的弹性能力,也需要即时的准确性的那些关键任务性应用,那么他们应该选择带有即时一致性ACID支持的NoSQL数据库。

对于那些不需要即时数据一致性,比如社交网络内容和其他只需要保证最终一致性就可以满足的场景,支持BASE的NoSQL就足够满足需求了。

而对于需要深度分析、报告等严苛商务操作的场景,还是传统的SQL最能胜任。

最后,现在有许多的数据库客供大家选择,甚至有的可以提供同样数据集NoSQL和SQL混合使用的技术。面对这些种种选择,还是需要考虑实际应用场景再做选择,SQL和NoSQL都有各自的优点和不足,只有把他们使用到了最适合的场景之中,才能发挥他们最大的作用!

《NoSQL数据库入门》,高清PDF 版下载见

NoSQL数据库的基础知识

企业应用NoSQL的关键

本文永久更新链接地址:

linux

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

oracle需要多少内存 oracle需要多少内存 May 10, 2024 am 04:12 AM

Oracle 所需内存量取决于数据库大小、活动水平和所需性能水平:用于存储数据缓冲区、索引缓冲区、执行 SQL 语句和管理数据字典缓存。具体数量受数据库大小、活动水平和所需性能水平影响。最佳实践包括设置适当的 SGA 大小、调整 SGA 组件大小、使用 AMM 和监控内存使用情况。

oracle数据库服务器硬件配置要求 oracle数据库服务器硬件配置要求 May 10, 2024 am 04:00 AM

Oracle 数据库服务器硬件配置要求:处理器:多核,主频至少 2.5 GHz,大型数据库建议 32 核以上。内存:小型数据库至少 8GB,中等规模 16-64GB,大型数据库或高负载工作负载高达 512GB 或更多。存储:SSD 或 NVMe 磁盘,RAID 阵列提高冗余和性能。网络:高速网络(10GbE 或更高),专用网卡,低延迟网络。其他:稳定电源、冗余组件、兼容操作系统和软件、散热和冷却系统。

iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 Jul 18, 2024 am 05:48 AM

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

在PHP中使用MySQLi建立数据库连接的详尽教程 在PHP中使用MySQLi建立数据库连接的详尽教程 Jun 04, 2024 pm 01:42 PM

如何在PHP中使用MySQLi建立数据库连接:包含MySQLi扩展(require_once)创建连接函数(functionconnect_to_db)调用连接函数($conn=connect_to_db())执行查询($result=$conn->query())关闭连接($conn->close())

如何在PHP中处理数据库连接错误 如何在PHP中处理数据库连接错误 Jun 05, 2024 pm 02:16 PM

PHP中处理数据库连接报错,可以使用以下步骤:使用mysqli_connect_errno()获取错误代码。使用mysqli_connect_error()获取错误消息。通过捕获并记录这些错误信息,可以轻松识别并解决数据库连接问题,确保应用程序的顺畅运行。

如何在 Golang 中使用数据库回调函数? 如何在 Golang 中使用数据库回调函数? Jun 03, 2024 pm 02:20 PM

在Golang中使用数据库回调函数可以实现:在指定数据库操作完成后执行自定义代码。通过单独的函数添加自定义行为,无需编写额外代码。回调函数可用于插入、更新、删除和查询操作。必须使用sql.Exec、sql.QueryRow或sql.Query函数才能使用回调函数。

如何用 Golang 连接远程数据库? 如何用 Golang 连接远程数据库? Jun 01, 2024 pm 08:31 PM

通过Go标准库database/sql包,可以连接到MySQL、PostgreSQL或SQLite等远程数据库:创建包含数据库连接信息的连接字符串。使用sql.Open()函数打开数据库连接。执行SQL查询和插入操作等数据库操作。使用defer关闭数据库连接以释放资源。

Go WebSocket 如何与数据库集成? Go WebSocket 如何与数据库集成? Jun 05, 2024 pm 03:18 PM

如何将GoWebSocket与数据库集成:设置数据库连接:使用database/sql包连接到数据库。将WebSocket消息存储到数据库:使用INSERT语句将消息插入数据库。从数据库检索WebSocket消息:使用SELECT语句检索数据库中的消息。

See all articles