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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux中vim编辑器的使用

vim常见使用方法 vim介绍命令模式下常用命令用法底行模式下常见命令用法注释代码删除 vim细节vim的配置问题 vim介绍 vim是一款多模式的编辑器 所谓多模式就是有几种模式供我们选择使用 创建一个文件叫test.c,用vim打开就是 vim test.c这样就可以打开test.c进行编…

运维SRE-04 磁盘管理体系

磁盘管理体系详解 磁盘管理系统概述 目标 熟练掌握常用磁盘配置(容量,转速,个数)熟练说出来或写出来: raid级别熟练掌握磁盘基础使用:拿到一块硬盘到可以向硬盘写入数据分区,格式化,挂载熟练掌握: 磁盘空间不足 no space left on device 故障,原因,排查,解决. 磁盘基础内容 …

17.Golang channel的基本定义及使用

目录 概述实践无缓冲 channel代码结果 缓冲 channel代码结果 channel的关闭特点代码结果range代码结果 select channel代码结果 结束 概述 此篇文章介绍 channel 的用法 无缓冲 channel缓冲 channelchannel的关闭特点range channelselect channel 每一种,配上完整…

深入浅出AI落地应用分析:AI个人助手Monica

前言:铺天盖地的大模型以及所谓的应用到目前为止实际还是很少有像Monica这样贴合个人工作习惯的产品落地,比如像Chatgpt等这样的产品,绝大多数人不会专门买🪜翻墙出去用,而且大多数场景下素人或小白都不知道该怎么用,但是Monica这款产品就很好的以浏览器的插件的形式始终…

29 python快速上手

Python操作MySQL和实战 1. 事务1.1 MySQL客户端1.2 Python代码 2. 锁2.1 排它锁2.2 共享锁 3. 数据库连接池4. SQL工具类4.1 单例和方法4.2 上下文管理 5.其他总结 目标:掌握事务和锁以及Python操作MySQL的各种开发必备知识。 概要: 事务锁数据库连接池…

【Oracle云】使用 boto3 访问 OCI 对象存储 (AWS S3协议兼容)

在现代云计算环境中,S3(Simple Storage Service)协议已经成为云对象存储的事实标准。它提供了简单、可扩展、高度耐用的存储解决方案,得到了广泛应用。Oracle Cloud Infrastructure(OCI)秉承着开放性和灵活…

摄像头监控系统/视频监控云平台EasyCVR接入单兵设备后如何配置移动规矩

视频云存储/安防监控EasyCVR视频汇聚平台基于云边端智能协同,支持海量视频的轻量化接入与汇聚、转码与处理、全网智能分发、视频集中存储等。音视频流媒体视频平台EasyCVR拓展性强,视频能力丰富,具体控可实现视频监控直播、视频轮播、视频录像…

Java编程练习之类的封装

1.把一个Student类封装起来,模拟一个转校生转入新学校后为其制作学生信息的过程。运行结果如下: package zhtestdemo; import java.util.Scanner; import java.text.DecimalFormat; public class demo { //创建类,类名叫demo; private Stud…

CentOS7中安装ElasticSearch

文章目录 检测是否安装了Elasticsearch安装JDK下载java配置 下载Elasticsearch解压安装Elasticsearch修改配置文件启动Elasticsearch常见问题 ElasticSearch是一个基于Lucene的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口。Elasti…

【Ubuntu 18.04 安装截图软件 flameshot 】

安装命令: sudo apt-get install flameshot 使用命令: flameshot gui 创建快捷键:设备->键盘->>输入名字和快捷键 截完图后保存CtrlS,复制到剪贴板 CtrlC ​​​​​​

Altium Designer的学习

PCB设计流程 1.新建空白工程: 创建一个新的工程 新建四个文件,并且保存: 每次打开文件时,打开以.PrjPcb结尾的文件 2.元件符号的创建: 在绘制图形的时候设置成10mil,为了在原理图中显得不那么大。 在绘制引脚的时候设…

【软考问题】-- 6 - 知识精讲 - 项目成本管理

一、基本问题 项目成本管理(预算内完成) 1:成本管理计划 定义:是项目管理计划的组成部分, 描述将如何规划、 安排和控制项目成本。在计划中一般要规定 计量单位精确度:例如 995.59 元取整为 1000元准确度&…

【Qt】—— Qt Creator界⾯认识

目录 (一)左边栏 (二)代码编辑区 (三)UI设计界⾯ (四)构建区 (一)左边栏 在编辑模式下,左边竖排的两个窗⼝叫做"边栏"。 ①是项⽬…

【TCP】三次握手(建立连接)

前言 在网络通信的世界里,可靠传输协议(TCP)扮演着重要的角色,它保证了数据包能够按顺序、完整地从发送端传送到接收端。TCP协议中有一个至关重要的机制——三次握手。这一过程确保了两个TCP设备在开始数据传输之前建立起一个稳定…

数字孪生产品评测:五款数字孪生产品的优劣对比

作为数据可视化领域的资深用户,我深知数字孪生产品在当今工业4.0时代的重要地位。本文将为大家介绍五款市面上的数字孪生产品,帮助大家了解各产品之间的优缺点,选择适合自己的产品。 一、山海鲸可视化 山海鲸可视化是一款强大而灵活的免费数…

C++(map和set)

目录 前言 正文 1.预备知识 1.1序列式容器 1.2关联式容器 1.3键值对 2.set 2.1概念 ​编辑 2.2set的使用 2.3set总结 2.4multiset 3.map 3.1概念 3.2、map的使用 3.3map中operator[] 3.4map总结 3.5multimap 前言 s et 和 map 是 STL 中的容器之一&a…

matlab自定义函数实现图像小波变换

matlab中提供了小波变换函数lwt和ilwt,可以方便地实现提升小波变换。 我们按照小波变换的定义,粗糙地实现一个针对图像的小波变换,如下: % 使用方法: img imread(lena256.bmp); % 假设lena.png是灰度图像 subplot(2…

单细胞转录组数据分析的10大软件/流程

单细胞数据分析现在已经有上千个软件工具可供使用了,这为用户带来便利的同时也造成了选择困难。就像时间一样,一个表,没问题,但如果有两个表,时间还不一样,该信谁的呢? 正好我们前面一篇文章介绍…

Windows10更新失败 错误 0x80070643、KB5034441的解决方法之二

Windows10更新失败 错误 0x80070643、KB5034441 在知乎Windows10更新失败 错误 0x80070643、KB5034441的原因分析和几个解决方法 - 知乎 参考文章进行操作,更详细信息自己看上面链接。 我电脑的硬盘是mbr格式,而且没有划分恢复分区。 Microsoft Windo…

JS(react)图片压缩+图片上传

上传dome var fileNodeTakeStock: any createRef();<inputref{fileNodeTakeStock}onChange{showPictureTakeStock}style{{ display: "none" }}id"fileInpBtn"type"file"accept"image/*" //限制上传格式multiple{false}capture&qu…