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.rhkb.cn/news/249561.html

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

相关文章

shell - 免交互

一.Here Document 免交互 1. 交互的概念 交互:当计算机播放某多媒体程序的时候,编程人员可以发出指令控制该程序的运行,而不是程序单方面执行下去,程序在接受到编程人员相应的指令后而相应地做出反应。 对于Linux操作系统中&…

Prometheus+grafana配置监控系统

使用docker compose安装 方便拓展, 配置信息都放在在 /docker/prometheus 目录下 1.目录结构如下 . ├── conf │ └── prometheus.yml ├── grafana_data ├── prometheus_data └── prometheus_grafana.yaml2.创建目录文件 mkdir /docker/prometheus &&am…

2024 springboot Mybatis-flex 打包出错

Mybatis-flex官网:快速开始 - MyBatis-Flex 官方网站 从 Mybatis-flex官网获取模板后,加入自己的项目内容想打包确保错,先试试一下方法 这里改成skip的默认是true改成false,再次打包就可以了

Unix环境高级编程-学习-04-匿名管道PIPE

目录 一、环境 二、介绍 三、C标准函数介绍 1、pipe 2、popen 3、pclose 4、注意 四、宏 五、常见的管道用法 1、一对一(父进程读子进程写一条管道) 2、一对一(父进程写子进程读一条管道) 3、一对多(父进程…

Windows Qt C++ VTK 绘制三维曲线

Qt 自带数据可视化从文档上看,只能实现三维曲面。 QwtPlot3D在Qt6.6.0上没编译通过。 QCustomPlot 只能搞二维。 VTK~搞起。抄官网demo。 后续需求: 1、对数轴 2、Y轴逆序 3、Z轴值给色带,类似等高线图的色带 期待各位大佬多多指导。…

vue前端页面时间显示问题解决方法

解决方法&#xff0c; <template slot-scope"scope"><span>{{ parseTime(scope.row.boxClosingOnlineTime, {y}-{m}-{d} {h}:{i}:{s}) }}</span> </template> 刷新页面&#xff1a; 此外&#xff0c;使用JsonFormat(pattern "yyyy-M…

C++ 哈希 开放定址法

哈希算法 哈希&#xff0c;是一种算法思想吗&#xff0c;它的核心是映射&#xff0c;哈希方法中使用的转换函数称为哈希(散列)函数&#xff0c;构造出来的结构称为哈希表(Hash Table)(或者称散列表) 在STL 中&#xff0c;提供了两个使用哈希底层实现的容器 unordered_set 和 …

【C++干货铺】哈希结构在C++中的应用

目录 unordered系列关联式容器 unordered_map unordered_map的接口说明 1.unordered_map的构造 2. unordered_map的容量 3. unordered_map的迭代器 4. unordered_map的元素访问 5. unordered_map的查询 6. unordered_map的修改操作 7. unordered_map的桶操作 底层结构 …

【unity小技巧】FPS简单的射击换挡瞄准动画控制

文章目录 射击动画控制换弹动画瞄准动画完结 射击动画控制 换弹动画 调用 瞄准动画 问题&#xff1a;瞄准时&#xff0c;但是动画会卡住&#xff0c;不会播放瞄准的待机动画 修改 调用 动画如果太快可以去修改播放速度 播放速度变慢了&#xff0c;可能导致切换待机动画也…

CS144--Chapter0--wsl2+docker环境搭建

我的笔记本配置 荣耀magicbook16&#xff0c;容量是500G&#xff0c;芯片是R7-5800 由于笔记本容量较小&#xff0c;因此考虑这个方案&#xff0c;对于台式机用户&#xff0c;建议可以直接用虚拟机或者双系统。 前言 斯坦福官网给出的方法是用他们的镜像&#xff08;基于Ubu…

Message Queue --- RabbitMQ

MessageQueue Intro 什么是MQ为什么使用MQ常见的MQ 什么是MQ MQ全称是Message Queue&#xff0c;消息的队列&#xff0c;因为是队列&#xff0c;所以遵循FIFO 先进先出的原则&#xff0c;它是一种跨进程的通信机制&#xff0c;用于上下游传递消息。在互联网架构中&#xff0c;M…

2024程序员的未来方向如何走?还看今朝

这几年的IT行业想必大家已经感受到了&#xff0c;Android、Java、前端等等程序员都经历了大厂裁员、小厂倒闭、找不到工作、毕业即失业的情况。大量失业是必然的&#xff0c;因为互联网公司都逐渐走向统一标准化&#xff0c;只剩下头部的一些大厂&#xff0c;所以市场需求少了。…

Spring实现事务(一)

Spring事务 .什么是事务事务的操作Spring中事务的实现准备工作创建表创建项目,引入Spring Web, Mybatis, mysql等依赖配置文件实体类 编程式事务(手动写代码操作事务)声明式事务(利用注解自动开启和提交事务) . 什么是事务 事务是⼀组操作的集合, 是⼀个不可分割的操作 在我们…

安装并开始设置 Windows 终端(命令提示符或Windows PowerShell或Azure Cloud Shell)

安装 安装 若要试用最新的预览功能&#xff0c;可能还需要安装 Windows 终端预览。 ‼️备注 如果你无法访问 Microsoft Store&#xff0c;GitHub 发布页上发布有内部版本。 如果从 GitHub 安装&#xff0c;Windows 终端将不会自动更新为新版本。 有关使用包管理器&#xff…

Qt QScrollArea 不显示滚动条 不滚动

使用QScrollArea时&#xff0c;发现添加的控件超出QScrollArea 并没有显示&#xff0c;且没有滚动条效果 原因是 scrollArea指的是scrollArea控件本身的大小&#xff0c;肉眼能看到的外形尺寸。 scrollAreaWidgetContents指的是scrollArea控件内部的显示区域&#xff0c;里面可…

51-17 视频理解串讲— MViT 论文精读

继TimeSformer模型之后&#xff0c;咱们再介绍两篇来自Facebook AI的论文&#xff0c;即Multiscale Vision Transformers以及改进版MViTv2: Improved Multiscale Vision Transformers for Classification and Detection。 本文由深圳季连科技有限公司AIgraphX自动驾驶大模型团…

Linux ---- Shell编程之函数与数组

目录 一、函数 1、函数的基本格式 2、查看函数列表 3、删除函数 4、函数的传参数 5、函数返回值 实验&#xff1a; 1.判断输入的ip地址正确与否 2. 判断是否为管理员用户登录 6、函数变量的作用范围 7、函数递归&#xff08;重要、难点&#xff09; 实验&#xff1…

力扣hot100 数据流的中位数 大小根堆

Problem: 295. 数据流的中位数 文章目录 思路复杂度&#x1f496; Code 思路 &#x1f468;‍&#x1f3eb; 参考 大根堆维护较小值&#xff08;堆顶即中位数&#xff09;&#xff0c;小根堆维护较大值&#xff08;堆顶可能是中位数之一&#xff09;维护小堆长度较长&#x…

第九节HarmonyOS 常用基础组件21-ImageAnimator

1、描述 提供帧动画组件来实现逐帧播放图片的能力&#xff0c;可以配置需要播放的图片列表&#xff0c;每张图片可以配置时长。 2、接口 ImageAnimator() 3、属性 参数名 参数类型 描述 images Array<ImageFrameInfo> 设置图片帧信息集合&#xff0c;每一帧的帧…

启动盘重装ubuntu22系统

win+R msinfo32查看 插入制作好的u盘电脑开机 进入BIOS界面的方法有多种,以下是一些常见的方法: 进入BIOS界面的最常见按键有: Del键:大多数台式机通过在启动时按下Del键来进入BIOS。Esc键:在AMI BIOS和某些品牌电脑中,进入BIOS系统需要按“Esc”键,一般在开机画面…