news 2026/4/18 7:10:17

一篇文章带你了解Redis数据类型

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
一篇文章带你了解Redis数据类型

前言

Redis作为高性能键值存储(缓存/数据库),其数据类型设计是“高性能+多场景适配”的核心,也是面试高频考点、业务开发必备技能。本文将分「核心数据类型」「拓展数据类型」两大模块,讲透每个类型的特点、常用命令、实战场景,并附加记忆技巧,帮你快速掌握~

一、Redis核心数据类型(5大基础)

1. String(字符串)

定位:Redis最基础、最“万能”的数据类型

  • 核心特点:存储文本、整数、二进制数据(最大512MB);支持原子操作(线程安全)。

  • 常用命令:

    • 增改查: SET key value / GET key ;
    • 原子运算: INCR key (自增)/ DECR key (自减);
  • 拓展操作: APPEND key str (追加)/ SETNX key value (分布式锁核心)。

  • 实战场景:缓存HTML片段/用户会话、文章阅读量计数器、简单分布式锁。

  • 记忆小贴士:“基础万能钥匙”——啥数据都能存,原子操作是核心优势。

2. Hash(哈希表)

定位:结构化对象的“专属存储容器”

  • 核心特点:本质是“键值对集合”(类似Java HashMap);可单独修改字段,无需传输整个对象。

  • 常用命令:

    • 单字段操作: HSET key field value / HGET key field ;
    • 多字段操作: HMSET key field1 val1 field2 val2 / HGETALL key ;
    • 删除: HDEL key field 。
  • 实战场景:存储用户信息、商品详情(仅修改单个字段,节省带宽)。

  • 记忆小贴士:“对象容器”——结构化数据存储首选,比String更灵活。

3. List(列表)

定位:有序双向操作的“队列/栈工具”

  • 核心特点:基于双向链表实现,按插入顺序排序;支持两端插入/弹出,支持阻塞弹出。

  • 常用命令:

    • 插入: LPUSH key val (左插)/ RPUSH key val (右插);
    • 弹出: LPOP key / RPOP key / BLPOP key (阻塞左弹);
    • 范围查询: LRANGE key start end ( 0 -1 获取所有元素)。
  • 实战场景:简单消息队列( LPUSH+BRPOP )、朋友圈/新闻最新动态列表。

  • 记忆小贴士:“双向队列”——左右操作灵活,阻塞弹出是消息队列基础。

4. Set(集合)

定位:无序去重+集合运算的“社交工具”

  • 核心特点:元素无序、唯一;支持交集、并集、差集运算。

  • 常用命令:

    • 增查: SADD key val / SMEMBERS key ;
    • 集合运算: SINTER key1 key2 (交集)/ SUNION key1 key2 (并集);
    • 成员检查: SISMEMBER key val (判断元素是否存在)。
  • 实战场景:文章标签系统(自动去重)、共同好友查询。

  • 记忆小贴士:“去重计算器”——自动去重+集合运算,适配社交/标签场景。

5. Sorted Set(有序集合)

定位:带分数排序的“排行榜工具”

  • 核心特点:元素唯一,关联 score (分数)排序;支持按score范围查询/逆序排序。

  • 常用命令:

    • 增: ZADD key score val ;
    • 查: ZRANGE key start end (升序)/ ZREVRANK key val (逆序排名);
    • 删: ZREM key val 。
  • 实战场景:游戏积分榜、延时队列(score存时间戳)。

  • 记忆小贴士:“带分的集合”——score是排序依据,天生适配排行榜。

核心数据类型对比表

数据类型核心优势典型实战场景
String基础万能存储+原子操作缓存、计数器、分布式锁
Hash结构化对象存储用户信息、商品详情
List双向有序操作+阻塞弹出消息队列、最新动态列表
Set无序去重+集合运算标签系统、共同好友
Sorted Set按score排序+范围查询排行榜、延时队列

二、Redis拓展数据类型(4大进阶,业务提效)

1. Bitmaps(位图)

定位:布尔型数据的“空间压缩器”

  • 本质:基于String的位操作(0/1表示状态)。
  • 核心特点:极省空间(1亿用户签到仅需12MB);支持位运算(与/或/异或)。
  • 常用命令: SETBIT key offset 0/1 (设定位)、 GETBIT key offset (获取位)、 BITCOUNT key (统计1的数量)。
  • 实战场景:用户签到统计、7天连续活跃用户计算( BITOP AND )。

2. HyperLogLog(基数统计)

定位:海量数据的“低内存去重计数器”

  • 本质:概率型数据结构,牺牲0.81%精度换内存。
  • 核心特点:内存固定(仅12KB);支持多HyperLogLog合并。
  • 常用命令: PFADD key val1 val2 (添加元素)、 PFCOUNT key (统计基数)、 PFMERGE destKey key1 key2 (合并)。
  • 实战场景:网站UV统计、千万级数据去重计数。

3. Geospatial(地理位置)

定位:LBS场景的“地理工具包”

  • 核心特点:存储经纬度;支持距离计算、范围查询。

  • 常用命令:

    • 添加位置: GEOADD key 经度 纬度 名称 (如 GEOADD shops 116.40 39.90 shop1 );
    • 计算距离: GEODIST key name1 name2 km ;
    • 范围查询: GEOSEARCH key FROMLONLAT 经度 纬度 BYRADIUS 5 km 。
  • 实战场景:外卖“附近商家”推荐、物流轨迹追踪。

4. Stream(流)

定位:Redis5.0+的“可靠消息队列”

  • 核心特点:支持多消费者组;消息可ACK确认、可回溯(避免丢失)。

  • 常用命令:

    • 生产消息: XADD key * field1 val1 ( * 自动生成消息ID);

    • 消费消息: XREAD GROUP groupName consumerName COUNT 5 STREAMS key > ;

    • 创建消费组: XGROUP CREATE key groupName 0 。

  • 实战场景:可靠分布式消息队列、系统操作事件溯源。

拓展数据类型对比表

数据类型核心优势典型实战场景
Bitmaps布尔状态+极致省空间用户签到、连续活跃统计
HyperLogLog海量数据+低内存去重网站UV统计、大数据去重计数
Geospatial地理信息存储+距离/范围查询附近商家推荐、物流轨迹追踪
Stream多消费组+消息可靠投递分布式消息队列、操作事件溯源

三、Redis数据类型选择口诀(快速记忆)

  • 存对象 → 选Hash;
  • 排顺序 → List(插入序)/ Sorted Set(score序);
  • 去重+集合运算 → Set;
  • 布尔状态+省空间 → Bitmaps;
  • 海量去重计数 → HyperLogLog;
  • LBS地理场景 → Geospatial;
  • 可靠消息队列 → Stream。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 3:26:53

EmotiVoice语音敬畏感合成尝试用于宗教场景

EmotiVoice语音合成在宗教场景中的敬畏感营造探索 在一座古老的教堂里,清晨的钟声刚落,一段低沉而庄严的诵读缓缓响起:“耶和华是我的牧者,我必不致缺乏……”声音浑厚、节奏舒缓,每一个音节都仿佛带着千年的重量。然而…

作者头像 李华
网站建设 2026/4/17 13:07:15

程序员必学!RAG技术详解+大模型学习资源全攻略(建议收藏)

RAG(Retrieval-Augmented Generation,检索增强生成)是一种结合信息检索与大语言模型(LLM)生成的技术框架,核心目标是通过检索外部知识库的精准信息,辅助 LLM 生成更准确、更具依据的回答&#x…

作者头像 李华
网站建设 2026/4/18 1:54:23

3.4 Docker 终极指南:一键部署你的多角色智能体系统

3.4 Docker 终极指南:一键部署你的多角色智能体系统 导语:我们已经成功地在本地开发并运行了“旅小智”这个由前端、后端和 AI 核心组成的全栈应用。但是,我们的“征途”还未结束。如何将这个由多个服务组成的复杂系统,方便、可靠地部署到任何地方?如何让一个新同事仅用一…

作者头像 李华
网站建设 2026/4/16 12:36:31

青否AI员工源头厂商agent工作流更加智能高效,支持私有化部署!

什么是Agent?为什么它能改变工作方式?简单来说,Agent就是一个能够理解你的需求,并自主调用各种工具来完成任务的AI助手。它不仅能理解你的问题,还能规划解决方案,调用合适的工具,最后整合结果呈…

作者头像 李华
网站建设 2026/4/11 12:51:51

LangChain数据流转全解析:RAG与Agent避坑技巧,收藏这篇就够了

在大模型应用迅猛发展之际,LangChain不再是小众的选择,逐步变为开发者于实现RAG、智能Agent等场景时的“必备框架”。它像一套“AI应用乐高组件包”,将数据加载、处理、存储、模型调用等繁杂流程拆分成标准化模块构件,普通用户也可…

作者头像 李华