Redis的数据结构到底是一种什么样的结构?

news2025/1/12 20:12:02

有了上一篇NoSQL的基础,我们也都知道了Redis就是一种典型的NoSql,那我们就先简简单单的介绍一下Redis:

Redis是什么?

Redis(Remote Dictionary Server)是一个开源的使用ANSI C语言编写的高性能键值存储系统,它以键值对(key-value)的形式存储数据,并提供了快速、稳定的数据读写操作。

以下是Redis的一些重要特点和结构:

  1. 键值存储:Redis使用键值对来存储数据。每个键都是唯一的,并且可以使用各种不同的数据类型作为值。
  2. 数据类型:Redis支持多种数据类型,包括字符串(string)、哈希(hash)、列表(list)、集合(set)、有序集合(sorted set)等。这些数据类型提供了灵活的数据操作方式。
  3. 内存存储:Redis的数据通常存储在内存中,这使得它能够提供非常快的数据读写速度。同时,Redis也支持将数据持久化到硬盘上,以便在重启后恢复数据。
  4. 持久化方式:Redis提供了两种持久化方式,即RDB(Redis Database)快照和AOF(Append-Only File)日志。RDB可以在指定时间间隔内将数据集快照存储到硬盘上,而AOF则记录了每个写操作的日志,通过重放日志来恢复数据。
  5. 高性能:Redis使用了多种优化技术来提供高性能的数据读写操作。其中包括使用单线程模型、基于内存的操作、异步IO等。

总的来说,Redis是一个高性能、灵活、可靠的键值存储系统,适用于各种场景,如缓存、消息队列、计数器、实时排行榜等。它不仅仅是一个简单的缓存工具,还提供了丰富的数据结构和强大的功能,使得开发人员可以更便捷地构建复杂的应用程序。

Redis的键和值分别是什么?

在Redis中,键和值分别指存储在Redis数据库中的数据对中的两部分。

键是什么?键是用来唯一标识某个数据项的标识符。它是一个字符串,用于将数据存储在Redis中并在需要时检索。键是唯一的,具有相同键的数据项将会被覆盖。

值是什么?值是存储在Redis数据库中与键相关联的实际数据。值可以是不同的数据类型,如字符串、哈希、列表、集合、有序集合等。根据不同的数据类型,值可以具有不同的操作和结构。

总结一下:通过上面的描述,我们知道,Redis的键通常只是String类型,而我们通常所说的Redis的数据类型,其实指的就是Redis的一个键值对的值,值的数据类型时多种多样的。这就是我们要学习Redis数据结构之前需要先了解的最重要的一点。

Redis常用五种数据结构?

1.String类型(字符串)

String类型,也就是字符串类型,是Redis中最简单的存储类型。其value是字符串,不过根据字符串的格式不同,又可以分为3类:

  • string:普通字符串

  • int:整数类型,可以做自增、自减操作

  • float:浮点类型,可以做自增、自减操作

不管是那种格式,底层都是字节数组形式存储,只不过是编码方式不同。字符串类型的最大空间不能超过512m

String类型的常见命令

 

key的层级结构

Redis的key允许有多个单词形成层级结构,多个单词之间用':'隔开,格式如下:

我们用:隔开后,会很自然的形成层级结构:

 

如果Value是一个Java对象,例如一个User对象,则可以将对象序列化为JSON字符串(实质还是string类型)后存储:

 

2.哈希类型

Hash类型,也叫散列,其value是一个无序字典,类似于Java中的HashMap结构。

为什么会有这种结构?

因为String结构存储json时是将对象序列化为JSON字符串后存储,当需要修改对象某个字段时很不方便,而Hash结构可以将对象中的每个字段独立存储,可以针对单个字段做CRUD:

String存json如下:

 

Hash结构存如下:

 

并且value中可以有多个字段,优势在于更加灵活,可以操作具体的value中的某个字段,而String不能做到。

Hash类型中的常见命令

 

3.list列表

Redis中的list类型与Java中的LinkedList类似,可以看做是一个双向链表结构。即可以支持正向检索也可以支持反向检索。

结构:user(键) 1 2 3(都是值)

值有多个;且是有序的,有索引。

特征也与LinkedList类似

  • 有序

  • 元素可以重复

  • 插入和删除一样块

  • 查询速度一般

常用命令:

 

4.set

Redis的Set结构与Java中的HashSet类似,可以看做是一个value为null的HashMap。因为也是一个hash表,因此具备与HashSet类似的特征:

  • 无序

  • 元素不可重复

  • 查找快

  • 支持交集、并集、差集等功能

存储的元素们是无序的,就是不按照添加的顺序,也不重复。

单个集合的操作:

sadd key 元素1,元素2,... 添加元素

srem key 元素 删除元素

smembers key 查看指定key中所有元素

scard key 查看元素数量

sismember key member:判断一个元素是否存在于set中

smembers:获取set中所有元素

多个集合之间的操作:

sinter key1 key2... :求key1与key2的交集

sdiff key1 key2... :求key1与key2的差集

sunion key1 key2... :求key1和key2的并集

5.zset

(sorted set:有序集合)

存储的元素们是可以排序(可以自己指定排序的规则)的set集合,也是不允许重复的。

Redis的SortedSet是一个可排序的set集合,与Java中的TreeSet有些类似,但底层数据结构却差别很大。SortedSet中的每一个元素都带有一个score属性,可以基于score属性对元素排序,底层的实现是一个跳表(SkipList)加hash表。SortedSet具备下列特性:

  • 可排序

  • 元素不重复

  • 查询速度快

因为SortedSet的可排序特性,经常被用来实现排行榜这样的功能。

注:member指添加进来的元素。

常见操作:

zadd key score member:添加一个或多个元素到sorted set。同时需要加入分数,这个分数是我们自己加入的。如果已经存在则更新其score值。

zrem key member:删除sorted set中的一个指定元素。

zscore key member:获取key中value指定元素member的score值。

zrank key member:获取key中指定元素member的排名。

zcard key:获取sorted set中的元素个数。

zcount key min max :统计score值在给定范围内的所有元素的个数。

zincrby key increment member:让sorted set中的指定元素自增,步长为指定的increment值。

zrange key min max:按照score排序后,获取指定排名范围内的元素。

zrangebyscore key min max:按照score排序后,获取指定score范围内的元素。

zdiff、zinter、zunion:求差集、交集、并集。

注:上述操作中的排名默认都是升序,如果要降序则在命令的第一个z字母后面添加REV即可。

总结

Redis是一个key-value的数据库,key一般是String类型,不过value的类型多种多样,以下的类型一般我们都指的是value的类型,键多是String,可能最多只会有什么层级结构;而value是多样的,比如value是set类型,那么存进去的就是多个set元素,相当于value就是一个set集合;再比如value类型是hash类型,就相当于与value中也进行键值对存储,而且可以有多对。

以上就是Redis中常用的数据结构,需要注意的是,上面提及的命令都是需要在控制端输入的,当然我们也可以使用一些可视化工具进行数据的操作。

 

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

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

相关文章

Kalman Filter VS Particle Filter

概率图模型 时间 -------->动态模型 动态模型有下面三种: 如果状态是离散的,就是我们上一节提到了Hidden Markov Model (HMM); 如果状态是连续的,如果状态之间的关系是线性的,就是Linear Dynamic System (Kalman …

【第二阶段】kotlin语言的匿名函数与具名函数

fun main() {//匿名函数val niminginfoniming("kotlin",20,{"$it"})println(niminginfo)//具名函数 理解:showResult:(String)->String):StringshowResultImpl(result:String):Stringval juminginfoniming("c ",20,::showResultI…

【jvm】类加载器的分类

目录 一、说明二、示例2.1 代码2.2 截图 一、说明 1.jvm支持两种类型的类加载器,分别是引导类加载器(bootstrap classloader)和自定义类加载器(user-defined classloader) 2.自定义类加载器一般指的是程序中由开发人员…

Python 中被忽视的核心功能

这篇文章主要介绍了一些在 Python 编程中可能被忽视的核心功能,包括默认参数、海象运算符、*args 和 **kwargs 的使用、变量交换、str 与 repr 的区别、可迭代对象的扩展解包、多个上下文管理器的使用、Python 调试器、collections.Counter 的使用、itertools 的使用…

Mysql高阶第一章 主从架构的复现

这里写目录标题 前言第一章 找到主数据库和从数据库对应的虚拟机1.1 查对应虚拟机IP1.2 rpm 查找数据库是否安装1.3 查找数据库详细配置信息 第二章 启动主从复制2.1 SHOW SLAVE STATUS\G;2.2 Slave_IO_Running: No2.3 解决方案2.3.1 进入slave中输入,停止从库同步&…

WebRTC音视频通话-新增或修改SDP中的码率Bitrate限制

WebRTC音视频通话-新增或修改SDP中的码率Bitrate限制参数 之前搭建ossrs服务,可以查看:https://blog.csdn.net/gloryFlow/article/details/132257196 之前实现iOS端调用ossrs音视频通话,可以查看:https://blog.csdn.net/gloryFlo…

PHP实践:分布式场景下的Session共享解决方案实现

🏆作者简介,黑夜开发者,全栈领域新星创作者✌,CSDN博客专家,阿里云社区专家博主,2023年6月CSDN上海赛道top4。 🏆数年电商行业从业经验,历任核心研发工程师,项目技术负责…

(1)window配置微软商店中的Ubuntu,及错误解决方法

(1)首先,在微软商店中搜索“Ubuntu”,下载你喜欢的版本(此处) (2)设置适用于window的Linux子系统,跟着红色方框走 点击“确定”之后,会提示你重启电脑,按要求重启电脑即可…

【算法题解】53. 计封闭岛屿的数目

这是一道 中等难度 的题 https://leetcode.cn/problems/number-of-closed-islands/ 题目 二维矩阵 grid 由 0 0 0(土地)和 1 1 1 (水)组成。岛是由最大的 4 4 4 个方向连通的 0 0 0 组成的群,封闭岛是一个 完全 由…

使用shift关键字,写一个带二级命令的脚本(如:docker run -a -b -c中的run)

省流:shift关键字 探索思路 最近有一个小小的需求,写一个类似于docker run -a -b -c这样的脚本,这个脚本名为doline,它本身可以执行(doline -a -b -c),同时又带有几个如run、init、start这样的…

【Pytroch】基于K邻近算法的数据分类预测(Excel可直接替换数据)

【Pytroch】基于K邻近算法的数据分类预测(Excel可直接替换数据) 1.模型原理2.数学公式3.文件结构4.Excel数据5.下载地址6.完整代码7.运行结果 1.模型原理 K最近邻(K-Nearest Neighbors,简称KNN)是一种简单但常用的机器…

python编程基础与案例集锦,python编程入门经典

大家好,本文将围绕python编程基础与案例集锦展开说明,python编程入门与案例详解是一个很多人都想弄明白的事情,想搞清楚python入门程序例子需要先了解以下几个事情。 【程序1】 题目:输入一行字符,分别统计出其中英文字…

【c++】七夕快到了却还没对象?手把手教你new一个出来!

前言 本章给大家带来的是C内存管理。在C语言阶段,我们经常使用malloc,calloc,realloc,free进行内存管理。但是,C语言的内存管理存在很多缺陷,会对程序的稳定性和安全性造成影响。 不过,C语言的…

cubemx hal stm32 舵机 可减速 任意位置停止 驱动代码

CubeMX配置 对于 STM32 F407VE 这里的84是来自APB1那路2倍频得到: 代码部分 两个舵机都是180度的 servo.c #include "servo.h" #include "tim.h" #include "stdio.h"__IO uint32_t g_SteerUWT[2] {0}; uint16_t g_SteerDeg[…

开发一个RISC-V上的操作系统(七)—— 硬件定时器(Hardware Timer)

目录 往期文章传送门 一、硬件定时器 硬件实现 软件实现 二、上板测试 往期文章传送门 开发一个RISC-V上的操作系统(一)—— 环境搭建_riscv开发环境_Patarw_Li的博客-CSDN博客 开发一个RISC-V上的操作系统(二)—— 系统引导…

Monkey测试真的靠谱吗?

Monkey测试,顾名思义,就是模拟一只猴子在键盘上乱敲,从而达到测试被测系统的稳定性。Monkey测试,是Android自动化测试的一种手段,Monkey测试本身非常简单,Android SDK 工具支持adb Shell命令,实…

jvm里的内存溢出

目录 堆溢出 虚拟机栈和本地方法栈溢出(栈溢出很少出现) 方法区和运行时常量池溢出 本机内存直接溢出(实际中很少出现、了解即可) 堆溢出 堆溢出:最常见的是大list,list里面有很多元素 堆溢出该怎么解决…

C++红黑树

一、红黑树的概念 红黑树是一种二叉搜索树,在其每个节点上增加一个存储位用于表示节点的颜色,可以是Red或Black 通过对任何一条从根到叶子的路径上的各个节点着色方式的限制,红黑树确保没有一条路径比其他路径长两倍 红黑树的性质&#xff…

SQL | 汇总数据

9-汇总数据 9.1-聚集函数 在实际开发过程中,可能会遇到下面这些情况: 确定大于某个值的有多少行数据,比如游戏排行榜,查询玩家排行多少名。 获取表中某些行的和,比如双十一当天,某个用户总订单价格是多少…

208、仿真-51单片机脉搏心率与心电报警Proteus仿真设计(程序+Proteus仿真+配套资料等)

毕设帮助、开题指导、技术解答(有偿)见文未 目录 一、硬件设计 二、设计功能 三、Proteus仿真图 四、程序源码 资料包括: 需要完整的资料可以点击下面的名片加下我,找我要资源压缩包的百度网盘下载地址及提取码。 方案选择 单片机的选择 方案一&a…