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.mzph.cn/news/658691.shtml

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

相关文章

大数据学习之Redis,十大数据类型的具体应用(三)

目录 3.7 Redis位图(bitmap) 概念 需求 是什么 说明 能干嘛? 基本命令 3.7 Redis位图(bitmap) 概念 由0和1状态表现的二进制位的bit数组 需求 用户是否登陆过?Y / N 广告是否被点击过? 钉钉打…

深入理解G0和G1指令:C++中的实现与激光雕刻应用

系列文章 ⭐深入理解G0和G1指令:C中的实现与激光雕刻应用⭐基于二值化图像转GCode的单向扫描实现⭐基于二值化图像转GCode的双向扫描实现⭐基于二值化图像转GCode的斜向扫描实现基于二值化图像转GCode的螺旋扫描实现基于OpenCV灰度图像转GCode的单向扫描实现基于Op…

RK3568平台 热插拔机制

一.热插拔的基本概念 热插拔是指在设备运行的情况下,能够安全地插入或拔出硬件设备,而无需关闭或重启系统。这意味着你可以在计算机或其他电子设备上插入或拔出硬件组件(比如USB设备,扩展卡,硬件驱动器等)…

计算机网络-调度算法-2(时间片轮转 优先级调度算法 多级反馈队列调度算法 多级队列调度算法)

文章目录 总览时间片轮转时间片大小为2时间片大小为5若按照先来先服务算法 优先级调度算法例题( 非抢占式优先级调度算法)例题( 抢占式优先级调度算法)补充 思考多级反馈队列调度算法例题 小结多级队列调度算法 总览 时间片轮转 …

设计模式学习笔记02(小滴课堂)

江湖传言里的设计模式-单例设计模式 单例设计模式中的懒汉方式实战 这种方式是线程不安全的,多个线程同时调用会创建多个对象。 所以我们就要给它加锁: 我们去测试一下: 因为构造函数已经私有化,所以不能直接用new的方式去创建对象。 现在我…

springboot本地测试

文章目录 本地测试引入依赖进入StudentMapper右键点击生成 项目结构 本地测试 引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope> </d…

笔记本从零安装ubuntu系统+多种方式远程控制

文章目录 前言ubuntu启动盘Windows远程Ubuntu安装XrdpXrdp卡顿问题解决Xrdp 二次登录会死机的问题Xrdp 卡顿问题 MobaXtermRustDesk 外网远程VNC 远程SSH远程其它设置 总结 前言 我有台老笔记本&#xff0c;上大学第一年的时候买的&#xff0c;现在已经不怎么好用了。打算刷个…

初谈C++:引用

文章目录 前言概述引用特性应用场景做参数做返回值 传值、传引用效率比较引用和指针的区别 前言 在学习C语言的时候会遇到指针&#xff0c;会有一级指针、二级指针…很容易让人头昏脑胀。在C里面&#xff0c;引入了引用的概念&#xff0c;会减少对指针的使用。引用相当于给一个…

日历功能——C语言

实现日历功能&#xff0c;输入年份月份&#xff0c;输出日历 #include<stdio.h>int leap_year(int year) {if(year % 4 0 && year % 100 ! 0 || year % 400 0){return 1;}else{return 0;} }int determine_year_month_day(int *day,int month,int year) {if(mo…

ECharts 图表嵌入表格样式的demo

心累。。。 如果条件允许&#xff0c;还是强烈建议 用 Echartshtml 来实现&#xff08;表格部分由 html 来弄&#xff09;。 这里是调研阶段&#xff0c;想看看 ECharts 原生能做到什么程度。 先贴上样图&#xff1a; 贴上完整代码&#xff1a; <!DOCTYPE html> <…

SQL注入攻击 - 基于布尔的盲注

环境准备:构建完善的安全渗透测试环境:推荐工具、资源和下载链接_渗透测试靶机下载-CSDN博客 查看靶场详情:SQL Injections 一、判定是否有注入点 以下是一个常见的步骤: 在URL中尝试输入特殊字符,如: " \ -- 等,并观察页面返回的内容。在URL中尝试输入错误的…

MySQL:MVCC原理详解

MySQL是允许多用户同时操作数据库的&#xff0c;那么就会出现多个事务的并发场景。那么再并发场景会出现很多问题&#xff1a;脏读、不可重复读、幻读的问题。 而解决这些问题所用到的方法就是&#xff1a;MVCC 多版本并发控制。而这个MVCC的实现是基于read_view、undoLog 如…

【Linux驱动】块设备驱动(一)—— 注册块设备

针对块设备驱动将分为两部分介绍&#xff0c;第一部分是注册块设备&#xff0c;即将块设备成功添加到内核&#xff1b;第二部分是介绍如何读写块设备&#xff0c;因为没有实际块设备&#xff0c;这里选择使用内存来模拟块设备。 一、认识块设备 1、什么是块设备 块设备针对的…

浏览器内存泄漏排查指南

1、setTimeout执行原理 使用setInterval/setTimeOut遇到的坑 - 掘金 2、Chrome自带的Performance工具 当我们怀疑页面发生了内存泄漏的时候&#xff0c;可以先用Performance录制一段时间内页面的内存变化。 点击开始录制执行可能引起内存泄漏的操作点击停止录制 如果录制结束…

【Java基础】之进程与线程

进程与线程 1. 线程与进程1.1 概念1.2 区别与联系 2. 线程的5种状态和切换2.1 简单介绍2.2 状态切换2.2.1 重点情况 3. 线程中常见的方法4. 线程池 1. 线程与进程 1.1 概念 进程&#xff1a;资源分配的基本单元&#xff0c;如QQ音乐 线程&#xff1a;资源调度的基本单元&…

关于美图秀秀如何给证件照快速抠图换背景操作

日常生活中一些经常处理的小技巧&#xff0c;记录以备以后使用&#xff0c;也方便别人&#xff0c;希望能帮到大家。 1、先导入一张相片&#xff0c;点击AI人像抠图&#xff1b; 2、再点应用当前效果&#xff1b; 3、再点击自动抠图或手动抠图或形状抠图;就可以点击换背景 4、…

Pyecharts绘制多彩气泡图:从基础到高级定制【第49篇—python:多彩气泡图】

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

Git 介绍 与 配置

Git 介绍 Git是一个分布式版本控制系统&#xff0c;用于跟踪文件的更改和协作开发。它可以管理项目的版本历史记录&#xff0c;并允许多个开发者在同一时间进行并行开发。 解决上图产生的问题就出现了git 分布式版本控制系统 看下图 Git 配置 Git的基本配置包括用户名和电子邮…

leetcode hot100岛屿的最大面积

本题是让求岛屿的最大面积&#xff0c;和上一个题求岛屿的数量类似&#xff0c;也是通过dfs或者bfs进行求解。 那么&#xff0c;首先我们判断dfs函数的参数&#xff0c;需要grid[][]&#xff0c;需要横坐标i&#xff0c;纵坐标j。那么&#xff0c;这里我们求的是最大面积&…

2万块的郎酒,都是我们惯的

文 | 琥珀酒研社 作者 | 五画 当我看到郎酒拿出快2万一瓶纪念酒的时候&#xff0c;我就知道&#xff0c;这场高价酒的喧嚣和吵闹&#xff0c;又到了一个新的高度。 和别的行业有所不同&#xff0c;白酒很少谈智商税&#xff0c;再高的价格&#xff0c;总有个冠冕堂皇的理由。…