Redis数据类型详解

Redis数据类型详解

Redis 共有 5 种基本数据类型:String(字符串)、List(列表)、Set(集合)、Hash(散列)、Zset(有序集合)。

除了 5 种基本的数据类型之外,Redis 还支持 3 种特殊的数据类型:Bitmap、HyperLogLog、GEO。

数据类型 & 数据结构

以下是 Redis 各种数据类型及其对应的数据结构的表格:

数据类型对应的数据结构
字符串 (String)动态字符串(SDS)
哈希 (Hash)哈希表(ziplist、hashtable)
列表 (List)双向链表
集合 (Set)哈希表(无序集合)
有序集合 (ZSet)跳表(Skip List)+ 哈希表
位图 (Bitmap)位数组
HyperLogLogHyperLogLog(近似计数算法)
地理位置 (Geospatial)有序集合(ZSet)

数据类型详解

Redis 提供了多种数据类型,每种数据类型的内部数据结构不同,适用于不同的场景。下面是 Redis 的主要数据类型及其相关信息:

1. 字符串(String)

  • 数据结构:动态字符串(SDS)
  • 应用场景
    • 缓存简单的键值对
    • 存储数字、JSON 字符串、图片等
    • 计数器、会话管理
  • 优点
    • 操作简单,速度极快
    • 支持高效的增减操作(如 INCR、DECR)
  • 缺点
    • 存储数据量有限制
    • 只能存储单一数据类型
  • 替代方案:Memcached

Java 代码示例

Jedis jedis = new Jedis("localhost");
jedis.set("name", "Redis");
String name = jedis.get("name");
System.out.println(name); // 输出: Redis

2. 哈希(Hash)

  • 数据结构:哈希表(ziplist、hashtable)
  • 应用场景
    • 存储对象的多个属性(如用户信息、商品信息、文章信息、购物车信息)
    • 数据分组和数据映射
  • 优点
    • 键值对存储,不需要对所有字段做操作
    • 适合存储多个字段数据
  • 缺点
    • 内存消耗较高(如果字段较多)
    • 不适合存储大规模数据
  • 替代方案:MongoDB、关系型数据库

Java 代码示例

Jedis jedis = new Jedis("localhost");
jedis.hset("user:1000", "name", "Alice");
jedis.hset("user:1000", "age", "30");
String name = jedis.hget("user:1000", "name");
System.out.println(name); // 输出: Alice

3. 列表(List)

  • 数据结构:双向链表
  • 应用场景
    • 消息队列
    • 最近访问的项目(如网页历史)
    • 栈(LIFO)和队列(FIFO)
  • 优点
    • 支持按序插入和删除
    • 适合消息队列和任务调度
  • 缺点
    • 对于大规模数据,操作可能较慢
    • 不支持直接索引
  • 替代方案:Kafka、RabbitMQ

Java 代码示例

Jedis jedis = new Jedis("localhost");
jedis.lpush("mylist", "item1", "item2", "item3");
List<String> items = jedis.lrange("mylist", 0, -1);
System.out.println(items); // 输出: [item3, item2, item1]

4. 集合(Set)

  • 数据结构:哈希表(无序集合)
  • 应用场景
    • 去重操作(网站 UV 统计(数据量巨大的场景还是 HyperLogLog更适合一些)、文章点赞、动态点赞等场景)
    • 社交网络中的用户关系(共同好友(交集)、共同粉丝(交集)、共同关注(交集)、好友推荐(差集)、音乐推荐(差集)、订阅号推荐(差集+交集) 等场景)
    • 标签、兴趣爱好等
  • 优点
    • 自动去重
    • 支持交集、并集、差集等操作
  • 缺点
    • 不支持按顺序遍历
    • 对内存消耗较大
  • 替代方案:MongoDB、PostgreSQL

Java 代码示例

Jedis jedis = new Jedis("localhost");
jedis.sadd("myset", "apple", "banana", "orange");
Set<String> items = jedis.smembers("myset");
System.out.println(items); // 输出: [banana, apple, orange]

5. 有序集合(Sorted Set,ZSet)

  • 数据结构:跳表(Skip List)+哈希表
  • 应用场景
    • 排行榜
    • 带权重的数据排序(如评分系统、各种排行榜比如直播间送礼物的排行榜、朋友圈的微信步数排行榜、王者荣耀中的段位排行榜、话题热度排行榜等)
    • 时间序列数据
  • 优点
    • 按顺序存储数据,支持排序和范围查询
    • 支持根据分数排序,灵活高效
  • 缺点
    • 内存消耗较大
  • 替代方案:Elasticsearch、MySQL

Java 代码示例

Jedis jedis = new Jedis("localhost");
jedis.zadd("myzset", 1, "apple");
jedis.zadd("myzset", 2, "banana");
Set<String> items = jedis.zrange("myzset", 0, -1);
System.out.println(items); // 输出: [apple, banana]

6. 位图(Bitmap)

  • 数据结构:位数组
  • 应用场景
    • 位标志操作(用户签到情况、活跃用户情况、用户行为统计(比如是否点赞过某个视频))
    • 高效统计
  • 优点
    • 空间占用小
    • 高效操作
  • 缺点
    • 只能用于位操作
  • 替代方案:BitSet(Java 标准库)

Java 代码示例

Jedis jedis = new Jedis("localhost");
jedis.setbit("mybitmap", 0, true); // 设置第0位为1
Boolean bit = jedis.getbit("mybitmap", 0);
System.out.println(bit); // 输出: true

7. HyperLogLog

  • 数据结构:HyperLogLog(近似计数算法)
  • 应用场景
    • 统计大规模唯一元素的基数(热门网站每日/每周/每月访问 ip 数统计、热门帖子 uv 统计)
  • 优点
    • 极低的内存消耗
    • 可以处理大规模数据
  • 缺点
    • 是近似值,可能存在误差
  • 替代方案:HLL 算法、Count-Min Sketch

8. 地理位置(Geospatial)

  • 数据结构:有序集合(ZSet)
  • 应用场景
    • 地理位置查询(如附近的餐厅、商店)
  • 优点
    • 支持范围查询、半径查询
  • 缺点
    • 需要维护坐标数据
  • 替代方案:Google Maps API、Elasticsearch

总结:

Redis 提供了多种数据结构,每种结构适用于不同的应用场景。在使用时,需要根据需求选择合适的数据类型。不同的类型在内存消耗、操作复杂度和查询效率上各有优势。对于特定场景,可以根据需要选择合适的替代方案,例如使用 Kafka 替代消息队列等。

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

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

相关文章

【第13章】亿级电商平台订单系统-高性能之异步架构设计

1-1 本章导学 课程导学 学习目标:掌握大型系统架构设计难点之高性能异步架构设计项目落地:订单系统高性能异步架构设计(年交易200亿B2B电商平台)本章主要内容 1. 为何需要异步消息架构 分析同步架构的性能瓶颈异步架构对系统解耦与性能提升的核心价值2. 确定异步消息技术…

2025-03-20 学习记录--C/C++-C 库函数 - toupper()、tolower()、 isspace()

合抱之木&#xff0c;生于毫末&#xff1b;九层之台&#xff0c;起于累土&#xff1b;千里之行&#xff0c;始于足下。&#x1f4aa;&#x1f3fb; 一、C 库函数 - toupper() ⭐️ C 标准库 - <ctype.h> C 标准库的 ctype.h 头文件提供了一些函数&#xff0c;可用于测试和…

LoRaWAN技术解析

LoRaWAN&#xff08;Long Range Wide Area Network&#xff09;是一种基于 LoRa&#xff08;Long Range&#xff09;技术的低功耗广域网络协议&#xff0c;专为物联网&#xff08;IoT&#xff09;设备的无线通信而设计。它是一种开放的、标准化的通信协议&#xff0c;支持大规模…

织梦DedeCMS如何获得在列表和文章页获得顶级或上级栏目名称

获得顶级或二级栏目的名称&#xff0c;都需要修改php文件&#xff0c;修改的文件【/include/common.func.php】将代码插入到这个文件的最下面即可&#xff1b; 一、获得当前文章或栏目的【顶级栏目】名称 1、插入顶级栏目代段 //获取顶级栏目名 function GetTopTypename($id…

虚幻基础:ue自定义类

文章目录 Gameplay Tag&#xff1a;ue标签类创建&#xff1a;其他-数据表格-gameplaytag安装&#xff1a;项目设置&#xff1a;gamePlayTag&#xff1a;gamePlay标签列表使用&#xff1a;变量类型&#xff1a;gamePlayTag primary data asset&#xff1a;ue数据类&#xff1a;通…

易语言模拟真人鼠标轨迹算法

一.简介 鼠标轨迹算法是一种模拟人类鼠标操作的程序&#xff0c;它能够模拟出自然而真实的鼠标移动路径。 鼠标轨迹算法的底层实现采用C/C语言&#xff0c;原因在于C/C提供了高性能的执行能力和直接访问操作系统底层资源的能力。 鼠标轨迹算法具有以下优势&#xff1a; 模拟…

Matplotlib 柱形图

Matplotlib 柱形图 引言 在数据可视化领域&#xff0c;柱形图是一种非常常见且强大的图表类型。它能够帮助我们直观地比较不同类别或组之间的数据大小。Matplotlib&#xff0c;作为Python中最受欢迎的数据可视化库之一&#xff0c;提供了丰富的绘图功能&#xff0c;其中包括创…

sparksql的Transformation与 Action操作

Transformation操作 与RDD类似的操作 map、filter、flatMap、mapPartitions、sample、 randomSplit、 limit、 distinct、dropDuplicates、describe&#xff0c;而以上这些都是企业中比较常用的&#xff0c;这里在一个文件中统一论述 val df1 spark.read.json("src/m…

微软Data Formulator:用AI重塑数据可视化的未来

在数据驱动的时代,如何快速将复杂数据转化为直观的图表是每个分析师面临的挑战。微软研究院推出的开源工具 Data Formulator,通过结合AI与交互式界面,重新定义了数据可视化的工作流。本文将深入解析这一工具的核心功能、安装方法及使用技巧,助你轻松驾驭数据之美。 一、Dat…

20分钟上手DeepSeek开发:SpringBoot + Vue2快速构建AI对话系统

20分钟上手DeepSeek开发&#xff1a;SpringBoot Vue2快速构建AI对话系统 前言 在生成式AI技术蓬勃发展的今天&#xff0c;大语言模型已成为企业智能化转型和个人效率提升的核心驱动力。作为国产大模型的优秀代表&#xff0c;DeepSeek凭借其卓越的中文语义理解能力和开发者友…

神经网络中层与层之间的关联

目录 1. 层与层之间的核心关联&#xff1a;数据流动与参数传递 1.1 数据流动&#xff08;Forward Propagation&#xff09; 1.2 参数传递&#xff08;Backward Propagation&#xff09; 2. 常见层与层之间的关联模式 2.1 典型全连接网络&#xff08;如手写数字分类&#xf…

本地部署deepseek-r1建立向量知识库和知识库检索实践【代码】

目录 一、本地部署DS 二、建立本地知识库 1.安装python和必要的库 2.设置主目录工作区 3.编写文档解析脚本 4.构建向量数据库 三、基于DS,使用本地知识库检索 本地部署DS,其实非常简单,我写了一篇操作记录,我终于本地部署了DeepSeek-R1(图文全过程)-CSDN博客 安装…

String、StringBuffer、StringBuiler的区别

可变性 String是不可变的&#xff0c;这是因为String内部用于存储数据的char[]数组用了final关键字修饰&#xff0c;而且是private的&#xff0c;并且没有对外提供修改数组的方法。 StringBuffer和StringBuilder是可变的&#xff0c;它们内部的char数组没有用final关键字修饰。…

Certd自动化申请和部署SSL证书并配置https

服务器使用的华为云&#xff0c;之前SSL证书通过配置Cloudflare的DNS实现的&#xff0c;最近华为云备案提示需修改解析至境内华为云IP&#xff0c;若解析境外IP&#xff0c;域名无需备案&#xff0c;需注销或取消接入备案信息&#xff0c;改为使用Certd自搭建证书管理工具&…

git tag以及git

git tag 以及git 一、先说收获吧 1. git bash 在windows上 类似于linux的bash提供的shell命令行窗口&#xff0c;可以执行很多linux命令&#xff0c;cd pwd ls vim cat touch mkdir&#xff0c;还可以用正则匹配查看标签。相当于在windows上装了一个小的linux。git init myproj…

ESP8266通过AT指令配置双向透传

一、固件烧录 IO0接地后上电&#xff0c;进入烧录模式&#xff0c;烧录完成后去掉即可 二、参数配置 1、服务器端 ATCWMODE_DEF2 ATCWSAP_DEF"ESP8266","12345678",5,3 ATSAVETRANSLINK1,"192.168.4.2",9090,"UDP",8080 2、客户端…

【3D模型】【游戏开发】【Blender】Blender模型分享-狮头木雕附导入方法

导入方法&#xff1a; [Blender] 如何导入包含纹理的 .blend 模型文件 在 3D 建模和渲染工作中&#xff0c;Blender 是一款功能强大的免费开源软件。很多时候&#xff0c;我们需要导入 .blend 后缀的模型文件&#xff0c;同时确保纹理&#xff08;textures&#xff09;文件夹…

C# | 超简单CSV表格读写操作(轻松将数据保存到CSV,并支持读取还原)

C# | 超简单CSV表格读写操作&#xff08;轻松将数据保存到CSV&#xff0c;并支持读取还原&#xff09; 文章目录 C# | 超简单CSV表格读写操作&#xff08;轻松将数据保存到CSV&#xff0c;并支持读取还原&#xff09;一、上位机开发中的CSV应用背景二、CSV读写实战教学1. 基本对…

Git push后撤销提交

一、介绍 当某次更改完工程后&#xff0c;push了本地仓库到云端&#xff0c;但是发现有地方改错了&#xff0c;想撤销这次推送&#xff0c;或者某次提交就更改了很小一部分&#xff0c;想和本地这次修改的合并为一次推送&#xff0c;省的在云端显示特别多次提交&#xff0c;显得…

Unity导出WebGL,无法显示中文

问题&#xff1a;中文无法显示 默认字体无法显示中文 在编辑器中设置了中文和英文的按钮&#xff0c;中文按钮无法显示 导出后无法显示中文 解决办法&#xff1a; 自己添加字体&#xff0c;导入项目&#xff0c;并引用 示例 下载一个字体文件&#xff0c;这里使用的阿里…