当前位置: 首页 > news >正文

Redis常用数据类型及其应用案例

文章目录

  • Redis常用数据类型及其应用案例
    • 1. 字符串(String)
      • 1.1 简介
      • 1.2 应用案例
        • 1.2.1 缓存
        • 1.2.2 计数器
    • 2. 哈希(Hash)
      • 2.1 简介
      • 2.2 应用案例
        • 2.2.1 存储用户信息
        • 2.2.2 购物车
    • 3. 列表(List)
      • 3.1 简介
      • 3.2 应用案例
        • 3.2.1 消息队列
        • 3.2.2 最新消息列表
    • 4. 集合(Set)
      • 4.1 简介
      • 4.2 应用案例
        • 4.2.1 标签系统
        • 4.2.2 好友关系
    • 5. 有序集合(Sorted Set)
      • 5.1 简介
      • 5.2 应用案例
        • 5.2.1 排行榜
        • 5.2.2 时间轴
    • 6. 总结


Redis常用数据类型及其应用案例

Redis(Remote Dictionary Server)是一个开源的、基于内存的高性能键值存储系统。它支持多种数据类型,适用于各种应用场景。本文将介绍Redis中常用的数据类型,并通过实际案例展示它们的应用。

1. 字符串(String)

1.1 简介

字符串是Redis中最基本的数据类型,可以存储文本、数字或二进制数据。每个键最多可以存储512MB的数据。

1.2 应用案例

1.2.1 缓存

字符串常用于缓存数据,例如缓存用户信息、页面内容等。

# 设置缓存
SET user:1 "{'name': 'Alice', 'age': 25}"# 获取缓存
GET user:1

在这里插入图片描述

1.2.2 计数器

字符串还可以用作计数器,例如统计网站的访问量。

# 初始化计数器
SET visit_count 0# 增加计数
INCR visit_count# 获取当前计数
GET visit_count

在这里插入图片描述

2. 哈希(Hash)

2.1 简介

哈希是一个键值对集合,适合存储对象。每个哈希可以存储多达2^32 - 1个字段-值对。

2.2 应用案例

2.2.1 存储用户信息

哈希适合存储对象的多个属性,例如用户信息。

# 设置用户信息
HSET user:1 name "Alice"
HSET user:1 age 25
HSET user:1 email "alice@example.com"# 获取用户信息
HGET user:1 name
HGETALL user:1

在这里插入图片描述
在这里插入图片描述

2.2.2 购物车

哈希可以用来存储用户的购物车信息。

# 添加商品到购物车
HSET cart:1 item1 2
HSET cart:1 item2 1# 获取购物车内容
HGETALL cart:1

3. 列表(List)

3.1 简介

列表是一个有序的字符串集合,可以在列表的两端进行插入和删除操作。列表的最大长度为2^32 - 1。

3.2 应用案例

3.2.1 消息队列

列表可以用作消息队列,实现生产者-消费者模式。

# 生产者:添加消息到队列
LPUSH message_queue "Task 1"
LPUSH message_queue "Task 2"# 消费者:从队列中获取消息
RPOP message_queue

在这里插入图片描述
在这里插入图片描述

3.2.2 最新消息列表

列表可以用来存储最新的消息或动态。

# 添加最新消息
LPUSH latest_messages "Message 1"
LPUSH latest_messages "Message 2"# 获取最新的5条消息
LRANGE latest_messages 0 4

添加4、5后,1已被消费
在这里插入图片描述

4. 集合(Set)

4.1 简介

集合是一个无序的、不重复的字符串集合。集合的最大成员数为2^32 - 1。

4.2 应用案例

4.2.1 标签系统

集合可以用来存储对象的标签。

# 添加标签
SADD post:1:tags "Redis"
SADD post:1:tags "Database"# 获取所有标签
SMEMBERS post:1:tags

在这里插入图片描述

4.2.2 好友关系

集合可以用来存储用户的好友关系。

# 添加好友
SADD user:1:friends user:2
SADD user:1:friends user:3# 获取共同好友(交集)
SINTER user:1:friends user:2:friends

在这里插入图片描述
在这里插入图片描述

5. 有序集合(Sorted Set)

5.1 简介

有序集合是一个有序的、不重复的字符串集合。
元素唯一性:有序集合中的元素是唯一的,不允许重复。
分数排序:每个元素都关联一个分数(score),Redis 根据分数对元素进行排序。
高效操作:支持高效的插入、删除和范围查询操作。

5.2 应用案例

5.2.1 排行榜

有序集合可以用来实现排行榜功能。

# 添加分数
ZADD leaderboard 100 "Alice"
ZADD leaderboard 200 "Bob"# 获取排行榜前3名
ZREVRANGE leaderboard 0 2 WITHSCORES

在这里插入图片描述
在这里插入图片描述

5.2.2 时间轴

有序集合可以用来存储按时间排序的事件。

# 添加事件
ZADD timeline 1633072800 "Event 1"
ZADD timeline 1633076400 "Event 2"# 获取最近的事件
ZRANGE timeline 0 -1 WITHSCORES

在这里插入图片描述

6. 总结

Redis提供了丰富的数据类型,每种类型都有其独特的应用场景。通过合理选择和使用这些数据类型,可以极大地提高应用的性能和灵活性。本文介绍了字符串、哈希、列表、集合和有序集合的常见应用案例,希望能帮助读者更好地理解和应用Redis。

在实际开发中,应根据具体需求选择合适的数据类型,并注意数据的一致性和性能优化。通过不断实践和探索,可以更好地发挥Redis的优势,构建高效、可靠的应用系统。

相关文章:

Redis常用数据类型及其应用案例

文章目录 Redis常用数据类型及其应用案例1. 字符串(String)1.1 简介1.2 应用案例1.2.1 缓存1.2.2 计数器 2. 哈希(Hash)2.1 简介2.2 应用案例2.2.1 存储用户信息2.2.2 购物车 3. 列表(List)3.1 简介3.2 应用…...

kafka数据拉取和发送

文章目录 一、原生 KafkaConsumer1、pom文件引入kafka2、拉取数据3、发送数据二、在spring boot中使用@KafkaListener1、添加依赖2、application.yml3、消息拉取:consumer4、自定义ListenerContainerFactory5、消息发送:producer6、kafka通过clientId鉴权时的鉴权失败问题一、…...

LLM全栈框架完整分类清单(预训练+微调+工具链)

一、预训练框架 1. 大规模分布式训练框架 框架名称核心能力GitHub地址Megatron-LM3D并行训练、FlashAttention支持、Transformer架构优化(NVIDIA生态)NVIDIA/Megatron-LMDeepSpeedZeRO优化系列、3D并行、RLHF全流程支持(微软生态&#xff09…...

蓝桥杯备考:贪心算法之矩阵消除游戏

这道题是牛客上的一道题,它呢和我们之前的排座位游戏非常之相似,但是,排座位问题选择行和列是不会改变元素的值的,这道题呢每每选一行都会把这行或者这列清零,所以我们的策略就是先用二进制把选择所有行的情况全部枚举…...

【Matlab仿真】Matlab Function中如何使用静态变量?

背景 根据Simulink的运行机制,每个采样点会调用一次MATLAB Function的函数,两次调用之间,同一个变量的前次计算的终值如何传递到当前计算周期来?其实可以使用persistent变量实现函数退出和进入时内部变量值的保持。 persistent变…...

DeepSeek 提示词:高效的提示词设计

🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/?__c1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编…...

深入学习Java中的Lambda表达式

深入学习Java中的Lambda表达式 自Java 8引入以来,Lambda表达式彻底改变了Java的编程风格,让代码变得更加简洁、易读,尤其是在函数式编程的场景中。接下来,我们将深入探讨Lambda表达式的语法、原理以及实际应用,帮助你…...

1.2 AI 量化炒股的起源与发展

**定性价值**:AI量化炒股通过算法模型实现投资决策自动化,显著提升交易效率与风险控制能力,打破传统人工交易的主观性与延迟性,推动金融科技向智能化、数据驱动方向迭代,具有颠覆传统投资模式的战略意义。 **定量价值…...

计算机单位之详解——存储单位Byte 网络传输单位bps 视频码率单位bps

前言: 计算机里面单位有点复杂,容易混淆,很多时候混起来就容易概念不理解,包括一些小问题,比如说:为什么我买了1T硬盘,实际存在虚标。为什么所谓的千兆宽带,下载起来没有1G每秒&…...

IDEA关闭SpringBoot程序后仍然占用端口的排查与解决

IDEA关闭SpringBoot程序后仍然占用端口的排查与解决 问题描述 在使用 IntelliJ IDEA 开发 Spring Boot 应用时,有时即使关闭了应用,程序仍然占用端口(例如:4001 端口)。这会导致重新启动应用时出现端口被占用的错误&a…...

deepseek清华大学第二版 如何获取 DeepSeek如何赋能职场应用 PDF文档 电子档(附下载)

deepseek清华大学第二版 DeepSeek如何赋能职场 pdf文件完整版下载 https://pan.baidu.com/s/1aQcNS8UleMldcoH0Jc6C6A?pwd1234 提取码: 1234 或 https://pan.quark.cn/s/3ee62050a2ac...

【python随手记】——读取文本文件内容转换为json格式

文章目录 前言一、TXT文件转换为JSON数组1.txt文件内容2.python代码3.输出结果 二、TXT文件转换为JSON对象1.txt文件2.python代码3.输出结果 前言 场景:用于读取包含空格分隔数据的TXT文件,并将其转换为结构化JSON文件 一、TXT文件转换为JSON数组 1.tx…...

k8s集群3主5从高可用架构(kubeadm方式安装k8s)

关键步骤说明 环境准备阶段 系统更新:所有节点执行yum/apt update确保软件包最新时间同步:通过ntpdate time.windows.com或部署NTP服务器网络规划:明确划分Service网段(默认10.96.0.0/12)和Pod网段(如Flann…...

基于 sklearn 的均值偏移聚类算法的应用

基于 sklearn 的均值偏移聚类算法的应用 在机器学习和数据挖掘中,聚类算法是一类非常重要的无监督学习方法。它的目的是将数据集中的数据点划分为若干个类,使得同一类的样本点彼此相似,而不同类的样本点相互之间差异较大。均值偏移聚类&…...

三、大模型微调的多种方法与应用场景

详解大模型微调的多种方法与应用场景 随着大模型的不断发展,如何有效地微调这些庞大的预训练模型以适应特定任务成为了研究和应用中的一个重要问题。大模型微调不仅能够提高任务性能,还能在不同的业务需求中提升模型的适应性。在本文中,我们…...

第2课 树莓派镜像的烧录

树莓派的系统通常是安装在SD卡上的‌。SD卡作为启动设备,负责启动树莓派并加载操作系统。这种设计使得树莓派具有便携性和灵活性,用户可以通过更换SD卡来更换操作系统或恢复出厂设置。 烧录树莓派的镜像即是将树莓派镜像烧录到SD卡上,在此期间会格式化SD卡,如果SD卡…...

SQL之order by盲注

目录 一.order by盲注的原理 二.注入方式 a.布尔盲注 b.时间盲注 三.防御 一.order by盲注的原理 order by子句是用于按指定列排序查询结果,列名或列序号皆可。 order by 后面接的字段或者数字不一样,那么这个数据表的排序就会不同。 order by 盲…...

AI大模型(四)基于Deepseek本地部署实现模型定制与调教

AI大模型(四)基于Deepseek本地部署实现模型定制与调教 DeepSeek开源大模型在榜单上以黑马之姿横扫多项评测,其社区热度指数暴涨、一跃成为近期内影响力最高的话题,这个来自中国团队的模型向世界证明:让每个普通人都能…...

java后端开发day19--学生管理系统升级

(以下内容全部来自上述课程) 1.要求及思路 1.总体框架 2.注册 3.登录 4.忘记密码 2.代码 1.javabean public class User1 {private String username;private String password;private String personID;private String phoneNumber;public User1() {…...

MFC文件和注册表的操作

MFC文件和注册表的操作 日志、操作配置文件、ini、注册表、音视频的文件存储 Linux下一切皆文件 C/C操作文件 const char* 与 char* const const char* 常量指针,表示指向的内容为常量。指针可以指向其他变量,但是内容不能再变了 char szName[6]&qu…...

浏览器访问 AWS ECS 上部署的 Docker 容器(监听 80 端口)

✅ 一、ECS 服务配置 Dockerfile 确保监听 80 端口 EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]或 EXPOSE 80 CMD ["python3", "-m", "http.server", "80"]任务定义(Task Definition&…...

接口测试中缓存处理策略

在接口测试中,缓存处理策略是一个关键环节,直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性,避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明: 一、缓存处理的核…...

React 第五十五节 Router 中 useAsyncError的使用详解

前言 useAsyncError 是 React Router v6.4 引入的一个钩子,用于处理异步操作(如数据加载)中的错误。下面我将详细解释其用途并提供代码示例。 一、useAsyncError 用途 处理异步错误:捕获在 loader 或 action 中发生的异步错误替…...

YSYX学习记录(八)

C语言&#xff0c;练习0&#xff1a; 先创建一个文件夹&#xff0c;我用的是物理机&#xff1a; 安装build-essential 练习1&#xff1a; 我注释掉了 #include <stdio.h> 出现下面错误 在你的文本编辑器中打开ex1文件&#xff0c;随机修改或删除一部分&#xff0c;之后…...

JVM垃圾回收机制全解析

Java虚拟机&#xff08;JVM&#xff09;中的垃圾收集器&#xff08;Garbage Collector&#xff0c;简称GC&#xff09;是用于自动管理内存的机制。它负责识别和清除不再被程序使用的对象&#xff0c;从而释放内存空间&#xff0c;避免内存泄漏和内存溢出等问题。垃圾收集器在Ja…...

全球首个30米分辨率湿地数据集(2000—2022)

数据简介 今天我们分享的数据是全球30米分辨率湿地数据集&#xff0c;包含8种湿地亚类&#xff0c;该数据以0.5X0.5的瓦片存储&#xff0c;我们整理了所有属于中国的瓦片名称与其对应省份&#xff0c;方便大家研究使用。 该数据集作为全球首个30米分辨率、覆盖2000–2022年时间…...

什么是库存周转?如何用进销存系统提高库存周转率?

你可能听说过这样一句话&#xff1a; “利润不是赚出来的&#xff0c;是管出来的。” 尤其是在制造业、批发零售、电商这类“货堆成山”的行业&#xff0c;很多企业看着销售不错&#xff0c;账上却没钱、利润也不见了&#xff0c;一翻库存才发现&#xff1a; 一堆卖不动的旧货…...

Linux云原生安全:零信任架构与机密计算

Linux云原生安全&#xff1a;零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言&#xff1a;云原生安全的范式革命 随着云原生技术的普及&#xff0c;安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测&#xff0c;到2025年&#xff0c;零信任架构将成为超…...

css的定位(position)详解:相对定位 绝对定位 固定定位

在 CSS 中&#xff0c;元素的定位通过 position 属性控制&#xff0c;共有 5 种定位模式&#xff1a;static&#xff08;静态定位&#xff09;、relative&#xff08;相对定位&#xff09;、absolute&#xff08;绝对定位&#xff09;、fixed&#xff08;固定定位&#xff09;和…...

Java入门学习详细版(一)

大家好&#xff0c;Java 学习是一个系统学习的过程&#xff0c;核心原则就是“理论 实践 坚持”&#xff0c;并且需循序渐进&#xff0c;不可过于着急&#xff0c;本篇文章推出的这份详细入门学习资料将带大家从零基础开始&#xff0c;逐步掌握 Java 的核心概念和编程技能。 …...