目录

    • 一、关系数据库的缺点
    • 二、常见的 NoSQL 方案分 类
      • 2.1、K-V 存储
      • 2.2、文档数据库
      • 2.3、列式数据库
      • 2.4、全文搜索引擎
    • 三、高性能 NoSQL 方案的典型特征和应用场景
      • 3.1、K-V 存储典型特征和应用场景
      • 3.2、文档数据库典型特征和应用场景
        • 3.1.1、文档数据库的 no-schema 特性的优势
        • 3.1.2、文档数据库的 no-schema 特性的劣势
      • 3.3、列式数据库典型特征和应用场景
      • 3.4、全文搜索引擎典型特征和应用场景
        • 3.4.1、全文搜索基本原理
        • 3.4.2、全文搜索的使用方式

本文来源:极客时间vip课程笔记

一、关系数据库的缺点

  • 关系数据库存储的是行记录,无法存储数据结构

    以微博的关注关系为例,“我关注的人”是一个用户 ID 列表,使用关系数据库存储只能将列表拆成多行,然后再查询出来组装,无法直接存储一个列表。

  • 关系数据库的 schema 扩展很不方便

    关系数据库的表结构 schema 是强约束,操作不存在的列会报错,业务变化时扩充列也比较麻烦,需要执行 DDL(data definition language,如 CREATE、ALTER、DROP 等)语句修改,而且修改时可能会长时间锁表(例如,MySQL 可能将表锁住 1 个小时)。

  • 关系数据库在大数据场景下 I/O 较高

    如果对一些大量数据的表进行统计之类的运算,关系数据库的 I/O 会很高,因为即使只针对其中某一列进行运算,关系数据库也会将整行数据从存储设备读入内存。

  • 关系数据库的全文搜索功能比较弱

    关系数据库的全文搜索只能使用 like 进行整表扫描匹配,性能非常低,在互联网这种搜索复杂的场景下无法满足业务要求。

二、常见的 NoSQL 方案分 类

2.1、K-V 存储

  • 解决关系数据库无法存储数据结构的问题,以 Redis 为代表。

2.2、文档数据库

  • 解决关系数据库强 schema 约束的问题,以 MongoDB 为代表。

2.3、列式数据库

  • 解决关系数据库大数据场景下的 I/O 问题,以 HBase 为代表。

2.4、全文搜索引擎

  • 解决关系数据库的全文搜索性能问题,以 Elasticsearch 为代表。

三、高性能 NoSQL 方案的典型特征和应用场景

3.1、K-V 存储典型特征和应用场景

  • K-V 存储的全称是 Key-Value 存储,其中 Key 是数据的标识,和关系数据库中的主键含义一样,Value 就是具体的数据。

  • Redis 是 K-V 存储的典型代表,它是一款开源(基于 BSD 许可)的高性能 K-V 缓存和存储系统。Redis 的 Value 是具体的数据结构,包括 string、hash、list、set、sorted set、bitmap 和 hyperloglog,所以常常被称为数据结构服务器。

  • 以 List 数据结构为例,Redis 提供了下面这些典型的操作(更多请参考链接:http://redis.cn/commands.html#list):

    LPOP key 从队列的左边出队一个元素。

    LINDEX key index 获取一个元素,通过其索引列表。

    LLEN key 获得队列(List)的长度。

    LLEN key 获得队列(List)的长度。

  • 以上这些功能,如果用关系数据库来实现,就会变得很复杂。例如,LPOP 操作是移除并返回 key 对应的 list 的第一个元素。如果用关系数据库来存储,为了达到同样目的,需要进行下面的操作:

    每条数据除了数据编号(例如,行 ID)

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

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

相关文章

正确选择光伏方案设计软件:人力成本优化的关键一步

在竞争激烈的市场环境中,企业无不追求效率提升与成本控制。设计环节作为产品开发的核心流程,其效率高低直接影响整体项目进度与资源消耗。错误的设计软件选择如同在信息高速公路上设置路障——它不会阻止前行,却会让每一次沟通、每一次修改都…

Git问题排查与故障解决详解

前言 在使用Git进行版本控制的过程中,开发者常常会遇到各种各样的问题和错误。本文将详细介绍常见的Git问题及其解决方法,帮助开发者快速定位和解决问题,避免在开发过程中浪费时间。 1. 基础错误与解决 1.1 身份配置问题 问题&#xff1a…

使用Xinference部署语音模型实现文本转语音:完整指南

文章目录引言环境准备1. 安装Xinference2. 启动Xinference服务3. 部署语音模型Python实现文本转语音关键参数说明应用场景性能优化建议常见问题解决结语引言 文本转语音(Text-to-Speech, TTS)技术在智能助手、有声读物、语音导航等应用中扮演着重要角色…

【C#】实体类定义的是long和值识别到的是Int64,实体类反射容易出现Object does not match target type

🌹欢迎来到《小5讲堂》🌹 🌹这是《C#》系列文章,每篇文章将以博主理解的角度展开讲解。🌹 🌹温馨提示:博主能力有限,理解水平有限,若有不对之处望指正!&#…

C#获取当前系统账户是否为管理员账户

传统方式:WindowsPrincipal winPrincipal new WindowsPrincipal(WindowsIdentity.GetCurrent()); bool admin winPrincipal.IsInRole(WindowsBuiltInRole.Administrator);这种方式虽然是最常用的检测管理员权限的方法,但是有个致命的缺陷,就…

【c++深入系列】:万字详解list(附模拟实现的list源码)

🔥 本文专栏:c 🌸作者主页:努力努力再努力wz 💪 今日博客励志语录: 当你觉得累的时候,说明你在走上坡路 ★★★ 本文前置知识: 模版 那么在之前的学习中,我们已经学习了…

PandaWiki与GitBook深度对比:AI时代的知识管理工具,选谁好?

在当今信息爆炸的时代,知识管理工具已成为个人学习、团队协作和企业文档管理的必需品。PandaWik作为AI时代迅速崛起的广受欢迎知识管理平台,代表了新一代AI驱动的知识库系统。本文将从功能特性、技术架构、适用场景等多个维度进行全面对比分析。产品定位…

清除 Android 手机 SIM 卡数据的4 种简单方法

SIM 卡存储了联系人、短信和通话记录等信息。在更换新 SIM 卡之前,彻底清除旧卡上的所有个人数据(如 SIM 卡联系人、短信、通话记录和手机号码)非常重要。要在 Android 手机上清除 SIM 卡内存,您可以参考以下方法。但在开始之前&a…

算法学习笔记:20.分治法——从原理到实战,涵盖 LeetCode 与考研 408 例题

分治法(Divide and Conquer)是计算机科学中最经典的算法设计思想之一,其核心思想是将复杂问题分解为若干个规模较小的子问题,通过解决子问题并合并结果来求解原问题。这种思想不仅在排序、搜索等基础算法中广泛应用,也…

@classmethod

1. 基本概念 classmethod 是 Python 中用于定义类方法的一种装饰器。类方法与常规的实例方法不同,它的第一个参数是 cls,表示类本身,而不是实例。 class MyClass:class_attr "Class Attribute"classmethoddef class_method(cls):p…

Qt 中使用 SQLite 数据库

一、SQLite 数据库介绍 SQLite 是一个轻量级的嵌入式关系型数据库管理系统,它以库的形式提供,不需要单独的服务器进程,直接访问存储在普通磁盘文件中的数据库。 主要特性 无服务器架构:SQLite 不需要单独的服务器进程 零配置&a…

【Unity】IL2CPP相关理论知识学习

一种编译技术。优点:性能优化:IL2CPP生成C代码后由本地编译器优化,一般在CPU性能和GC方面都优于Mono。特别在移动端或主机平台,性能差距更加明显。跨平台支持:Unity作为跨平台引擎,IL2CPP是支持iOS、Androi…

一个用于在 Ubuntu 22.04.3 LTS 上显示文件系统超级块信息的 C 程序

1.程序#include <stdio.h> #include <sys/statvfs.h> #include <errno.h>int main(int argc, char *argv[]) {const char *path;struct statvfs fs_info;// 检查参数if (argc ! 2) {fprintf(stderr, "用法: %s <挂载点或路径>\n", argv[0]);…

Git未检测到文件更改

背景 在本地仓库改动文件发现git检测不到修改了的文件&#xff0c;安装有Git状态可视化工具&#xff0c;文件改动后应该是红色标记&#xff0c;但是仍然是绿色的 git status&#xff0c;git diff等也都没有显示文件改动 原因 1.可能是文件命中了.gitignore文件过滤条件 检查后发…

Golang学习之常见开发陷阱完全手册

1. 指针的“温柔陷阱”&#xff1a;空指针与野指针的致命一击Go语言的指针虽然比C/C简单&#xff0c;但照样能让你“痛不欲生”。新手常觉得Go的指针“安全”&#xff0c;但真相是&#xff1a;Go并不会帮你完全规避指针相关的Bug。空指针&#xff08;nil pointer&#xff09;和…

【python】sys.executable、sys.argv、Path(__file__) 在PyInstaller打包前后的区别

文章目录sys.executable 的区别打包前打包后sys.argv 的区别打包前打包后Path(__file__) 的区别打包前打包后应用场景与解决方案总结在使用 PyInstaller 将 Python 脚本打包为独立可执行文件时&#xff0c; sys.executable、 sys.argv 和 Path(__file__) 的行为会发生变化。理…

JWT基础详解

JSON Web Token 简称JWT 一、起源&#xff1a; 这一切的起源都源于网景公司的一个天才程序员&#xff0c;为了解决http协议无状态问题&#xff0c;就让浏览器承担了一部分“记忆”责任&#xff08;每次客户端&#xff0c;访问服务器&#xff0c;自身就携带cookie&#xff0c;…

【Unity】MiniGame编辑器小游戏(十四)基础支持模块(游戏窗口、游戏对象、物理系统、动画系统、射线检测)

更新日期:2025年7月15日。 项目源码:获取项目源码 索引 基础支持模块一、游戏窗口 MiniGameWindow1.窗体属性2.快速退出键3.模拟帧间隔时间4.生命周期函数5.游戏状态二、游戏对象 MiniGameObject1.位置2.激活状态3.碰撞器4.限制游戏对象的位置5.生命周期函数6.移动三、物理系…

Swift6.0 - 5、基本运算符

目录1、术语2、赋值运算符&#xff08;a b&#xff09;3、算术运算符&#xff08;、-、*、/&#xff09;3.1、余数运算符&#xff08;%&#xff09;3.2、一元负号运算符&#xff08;-a&#xff09;3.3、一元正号运算符&#xff08;a&#xff09;4、复合赋值运算符&#xff08;…

DataWhale AI夏令营 Task2.2笔记

本次代码改进主要集中在聚类算法和主题词提取方法的优化上&#xff0c;主要包含三个关键修改&#xff1a;首先&#xff0c;将聚类算法从KMeans替换为DBSCAN。这是因为原KMeans方法需要预先指定聚类数量&#xff0c;而实际评论数据中的主题分布难以预测。DBSCAN算法能够自动确定…