NoSQL数据库简介

NoSQL数据库简介

Brief Introduction to NoSQL Databases

By Jackson@ML

1. 什么是SQL?

在了解NoSQL之前,先简要介绍一下SQL。

SQLStructured Query Language(结构化查询语言)的缩写。

SQL在关系型数据中广泛使用,一些大型关系型数据库,例如:Oracle Database, MySQL, PostgreSQL, Microsoft SQL Server, IBM DB2, SQLite, MariaDB等,均使用SQL语言来创建、修改和删除表,同时,还可以使用SQL语言进行数据库开发,便于用户长期按照特定需求使用关系型数据库。

2. 什么是NoSQL?

NoSQL既表示非关系型数据库,又表示不适用SQL(结构化查询语言)。

显而易见,这些数据库采用不同于关系表的格式来存储数据。但是,NOSQL数据库可以使用惯用语言API、声明性结构化查询语言以及按示例查询语言进行查询。

因此,从字面理解,也正是这类数据库被称为不仅仅是SQL数据库的原因所在。

3. NoSQL与SQL对比

NoSQL数据库的广泛应用,得益于高可用,以及高可扩展性。NoSQL数据库可作为开发人员的首选方案,它能适应不断变化的客户需求,也能够据此进行不断迭代,非常适合敏捷开发。

NoSQL数据库支持以更加直观和易于理解的方式进行数据存储,且在API存储或检索时所需的转换更少。

同时,NoSQL数据库也支持云计算,在云端部署NoSQL数据库可使得企业应用实现零停机。

4. NoSQL数据库与关系型数据库

1) 关系型数据库

关系型数据库由多个表组成,而表由列和行组成,是相关数据条目的集合。

表是典型的数据库对象,用来存储结构化数据。因此,关系型数据库需要预先定义好架构,也就是说,需要提前知道所有列以及相关联的数据类型,以便于应用程序将数据写出数据库。

同时,关系型数据库还通过键来链接多个表的信息,从而创建跨越多个表的关系。关系型数据库因而得名。

关系型数据库由Edgar F. Codd于1970年发明,通过为每行关联一个特定的键,将数据排列到不同的行和列中;几乎所有的关系型数据库管理系统(RDBMS)都是用结构化查询语言(SQL),并且非常复杂。

2) NoSQL数据库

在NoSQL数据库中,则无须预先定义架构,即可存储数据。这意味着数据库可迅速移动和不断迭代,从而动态定义数据模型。

这样的特点,适应特定的业务需求并满足敏捷开发的需要。
NoSQL数据库能够以图形和面向列、面向文档,以及作为键值对进行存储。

在1990年代中期,互联网得到了极大的普及,关系型数据库根本无法跟上用户所需的信息流,以及这种演变产生的更多种类的数据类型。这就导致了非关系型数据库(Non-relational
Database,也成为NoSQL Database)的发展。

5. 何时选择NoSQL数据库?

对于需要快速创新和迭代应用程序的企业而言,保持敏捷性至关重要,因为这关乎开发到运维的全过程。

NoSQL数据库提供灵活的架构,并且支持各种数据模型,非常适合构建大量数据和快速响应的应用程序,同时要求低延迟,例如:电子商务Web应用程序,或者在线游戏等。

此外,NoSQL数据库可以快速转换“奇怪“的数据(即形态各异的数据),并通过灵活地取代”有组织的“存储来避免SQL的僵化。

6. NoSQL数据库的演进及优势

1) NoSQL的演进

NoSQL作为缩略词,于1998年由Carlo Strozzi首次使用。当时,他将轻量级的开源“关系的“数据库命名为不使用SQL。

2009年,当Eric Evans和Johan Oskarsson用它来描述非关系型数据库时,这个名字NoSQL再次出现。

关系型数据库通常关联SQL;因此,新术语NoSQL很直观,就代表”No SQL Systems“(没有SQL系统);也有一种解释,是表示普遍可以接受的“Not only SQL”(不仅仅是SQL)的翻译,以强调某些系统可能支持类似SQL(结构化查询语言)这一既定事实。

2) NoSQL的优势

NoSQL自诞生起,就是为了响应日益庞大的Web数据,处理非结构化数据的需求,以及应对更加快捷处理的需求而开发的。NoSQL使用分布式数据库系统来处理大量不同类型的数据。

经过二十多年的积累和发展,数字交互和使用已经达到了前所未有的高水平,这就要求企业采用更加现代化且更加流畅的方法来存储数据以及访问数据。全球范围内的用户都要求实现不间断的内容服务及数据流,这就要求数据库也需要具备快速适应的能力。

无论是用户,还是开发人员,选择NoSQL数据库,都基于它的几点明显优势:

a) 灵活性

SQL 数据库将数据存储在更加严格的预定义结构中。NoSQL 则以更加自由的方式来存储数据,而无需严格的模式。这种设计可支持创新和快速应用开发。开发人员可以专注于创建系统来改善客户服务,无需担心模式。NoSQL 数据库可以轻松处理任何数据格式,例如单一数据存储中的结构化、半结构化和非结构化数据。

b) 可扩展性

NoSQL 数据库可以通过商用硬件来实现横向扩展,而不需要通过添加更多服务器来进行扩展。这可以支持流量增长,从而满足零停机需求。通过横向扩展,NoSQL 数据库可以扩充容量和处理能力,因此成为支持不断变化的数据集的首选方案。

c) 高性能

当数据量或流量增长时,NoSQL 数据库的横向扩展架构的优势尤为明显。如下图所示,该架构可实现快速、可预测的个位数毫秒级响应能力。NoSQL 数据库还可以摄取数据并快速可靠地交付数据,因此 NoSQL 数据库可支持应用每天收集 TB 级数据,同时实现高度交互的用户体验。

d) 可用性

NoSQL 数据库可自动跨多个服务器、数据中心或云资源复制数据。而这又可以大幅减少用户延迟,而不受其地理位置的限制。此特性还有助于减轻数据库管理的负担,从而腾出时间专注于其他优先事项。

e) 功能强大

NoSQL 数据库专为具有超高数据存储需求的分布式数据存储而设计。这使得 NoSQL 成为大数据、实时 Web 应用、360 度客户视图、在线购物、在线游戏、物联网、社交网络和在线广告应用的理想方案。

7. NoSQL数据库的类型

NoSQL 数据库可分为以下几种主要类型,请看下表。
在这里插入图片描述

表中的几类NoSQL数据库简要介绍如下。

• 键值数据库(Key-Value Databases)
这是极为灵活的 NoSQL 数据库类型,因为应用可以完全控制 value 字段中存储的内容,没有任何限制。代表性的数据库有Redis,Aerospike, Riak, Project Voldemort。
• 文档数据库(Document-Based Databases)
也称为文档存储或面向文档的数据库,这些数据库用于存储、检索和管理半结构化数据。无需指定文档将包含哪些字段。代表性的数据库有MongoDB,Couchbase Server, CouchDB, Elasticsearch。
• 图形数据库(Graph-Based Databases)
此数据库将数据组织为节点和关系,这将显示节点之间的连接。这支持更加丰富和完整的数据表示。图形数据库应用于社交网络、预订系统和欺诈检测。代表性的数据库有Neo4J, OrientDB, RedisGraph,InfiniteGraph。
• 宽列数据库(Wide Column-Based Databases)
这些数据库以表、行和列的形式来存储和管理数据。它们广泛部署于需要用列格式来捕获无模式数据的应用中。代表性的数据库有Apache Cassandra, Azure Comos DB, HBase, Accumulo。

• 对象数据库(Object-Based Databases)
对象数据库的典型例子是ObjectDB, 它是一个Java对象数据库解决方案,通过内建的Java API支持来完成Java应用程序开发,在客户端-服务器或嵌入式模式下工作。 代表性的对象数据库有ObjectDB, Ninja Database Pro, NeoDB, Objectivity/DB。

• 云和网格数据库(Cloud and Grid Databases)
一种分布式缓存和内存数据网格,构成了云和网格数据库。它管理集群应用程序中的数据,因此每次需要管理数据时,都无需直接查询数据库。代表性的数据库有Oracle Coherence, Infinispan, Hazelcast。

• 多模型数据库(Multi-Model Databases)
有代表性的数据库多模型数据库是ArangoDB, 它是一个开源数据库管理器,既支持键值,文档,又支持图形的数据库模型。代表性的数据库有: MarkLogic, ArangoDB, OrientDB, Azure Cosmos DB, FoundationDB, Couchbase, Apache Ignite。

8. 小结:

本文简要介绍了最流行的NoSQL数据库及其主要功能,同时对NoSQL的特点及优势作了阐述。为了适应快速发展的Web站点,尤其是电子商务类网站等,NoSQL数据库可谓是恰当的选择。它能提供敏捷开发、快速响应以及不断迭代的强大功能。

以上列出了主流的各类NoSQL数据库。后续有机会,也会针对MongoDB, Redis等展开讨论。感谢您的关注和点赞。

您的支持,我的动力! 😊

参考文献:

  1. Oracle中国
  2. Predictiveanalyticstoday.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/443370.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IS-IS:06 ISIS路由汇总

与OSPF 协议相同, IS-IS 也能够通过路由聚合来减少路由条目。不同的是,OSPF 只能在ABR 和ASBR 路由器上进行路由聚合,而IS-IS 路由器能否进行路由聚合以及对什么样的路由才能进行聚合取决于路由器的类型及路由的类型。 在IS-IS 网络中&#x…

生产问题排查系列——redis告警连接异常问题排查

项目背景 我们的项目使用redis的场景主要是有两种,一是使用redis缓存各种业务信息,二是使用redis做分布式锁。主要是引用了两个框架jedis和redisson。 Jedis是Redis的Java实现的客户端,其API提供了比较全面的Redis命令的支持; …

第16次修改了可删除可持久保存的前端html备忘录:做个可以隐藏的文本操作窗口,添加了选择文本拖动复制,配了背景主题:现代深色

第16次修改了可删除可持久保存的前端html备忘录&#xff1a;隐藏了文本操作按钮&#xff0c;添加了选择文本拖动复制&#xff0c;配了背景主题&#xff1a;现代深色 备忘录代码&#xff1a; <!DOCTYPE html> <html lang"zh-CN"><head><meta ch…

代码随想录算法训练营第二二天| 二叉搜索树的最近公共祖先、二叉搜索树中的插入操作、删除二叉搜索树中的节点

目录 二叉搜索树的最近公共祖先二叉搜索树中的插入操作删除二叉搜索树中的节点普通二叉树的删除方式 LeetCode 235. 二叉搜索树的最近公共祖先 LeetCode 701.二叉搜索树中的插入操作 LeetCode 450.删除二叉搜索树中的节点 二叉搜索树的最近公共祖先 给定一个二叉搜索树, 找到…

腾讯云SDK并发调用优化方案

目录 一、概述 二、 网关的使用 2.1 核心代码 三、腾讯云SDK依赖包的改造 一、概述 此网关主要用于协调腾讯云SDK调用的QPS消耗&#xff0c;使得多个腾讯云用户资源能得到最大限度的利用。避免直接使用腾讯云SDK 时&#xff0c;在较大并发情况下导致接口调用异常。网关的工…

漏洞原理SSRF漏洞

漏洞原理SSRF漏洞 服务器请求伪造 SSRF(Server Side Request Forgery)是一种服务器端请求伪造漏洞。它允许攻击者利用后端服务器来发送未经授权的请求。攻击者可以通过修改请求的目标地址,将请求发送到内部网络或其他受信任的服务器上,从而绕过防火墙和访问控制。 SSRF漏洞…

Pyecharts绘制多种炫酷气泡图

Pyecharts绘制多种炫酷气泡图 引言 数据可视化是数据分析中不可或缺的一环&#xff0c;而Pyecharts作为一款基于Echarts的Python图表库&#xff0c;提供了丰富的图表类型&#xff0c;其中气泡图是一种常用于展示三维数据的炫酷图表。本文将介绍如何使用Pyecharts绘制多种炫酷…

91 C++对象模型探索。RTTI运行时类型识别回顾 与 存储位置介绍

一&#xff0c;RTTI 运行时类型识别&#xff0c;简单回顾 C运行时类型识别RTTI&#xff0c;要求父类这种必须 至少有一个虚函数&#xff0c;如果父类中没有虚函数&#xff0c;那么得到的RTTI就不准确&#xff1b; RTTI就可以在执行期间查询一个多态指针&#xff0c;或者多态应…

五大架构风格之一:数据流风格

数据流风格详细介绍 系统架构数据流风格是一种软件体系结构风格&#xff0c;它强调了系统内部不同部分之间的数据流动。这种风格侧重于描述系统中的数据处理过程&#xff0c;以及数据是如何从一个组件传递到另一个组件的。以下是系统架构数据流风格的详细介绍&#xff1a; 1 基…

中国建设银行,这年终奖噶噶高!!!!(含算法原题)

国企年终 今天刷到一个近期帖子:「中国建设银行&#xff0c;这年终奖噶噶高!!!!」 先撇去具体内容不看&#xff0c;能在自然年的 月初&#xff0c;就把去年的奖金发了的企业&#xff0c;首先值得一个点赞。 再细看内容&#xff0c;年终奖是一个 字头的 位数。 由于国企通常没…

项目:博客

1. 运行环境&#xff1a; 主机 主机名 系统 服务 192.168.223.129 Server_Web Linux Web 192.168.48.131 Server-NFS-DNS Linux NFS/DNS 2. 基础配置 配置主机名&#xff0c;静态IP地址 开启防火墙并配置 部分开启SElinux并配置 服务器之间使用同ntp.aliyun.com进行…

鸿蒙harmony--TypeScript基础语法

把青春献给身后那座辉煌的都市&#xff0c;为了这个美梦我们付出着代价 目录 一&#xff0c;基础类型 二&#xff0c;数组 三&#xff0c;any 四&#xff0c;变量的类型注释 五&#xff0c;函数 5.1 参数类型注解 5.2 返回类型注解 5.3 匿名函数 六&#xff0c;对象类型 可选属…