news 2026/5/1 3:57:31

一篇文章带你了解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/5/1 1:56:48

3.6 线上问题排查实战:让你的 AI 服务 7x24 小时稳定运行

3.6 线上问题排查实战:让你的 AI 服务 7x24 小时稳定运行 导语:欢迎来到第三周的终极实战!我们已经成功地将“旅小智”部署到了云端。但是,部署成功只是一个新的开始。在真实的生产环境中,系统会在你意想不到的时间、以你意想不到的方式出现问题。当凌晨三点,告警短信将你…

作者头像 李华
网站建设 2026/4/16 13:56:34

9个AI论文工具,继续教育学员轻松搞定毕业写作!

9个AI论文工具,继续教育学员轻松搞定毕业写作! AI 工具助力论文写作,轻松跨越毕业难关 在继续教育的学习过程中,论文写作往往成为学员们最头疼的环节。无论是选题、开题还是撰写、降重,每一步都充满了挑战。而随着 AI …

作者头像 李华
网站建设 2026/4/27 10:37:04

47、基于PHP的订单系统开发与优化

基于PHP的订单系统开发与优化 1. 代码复用与数据处理 在Web开发里,可将多个网页的通用部分存于包含文件(include files)中,PHP函数也能通过这种方式轻松嵌入HTML源代码。这样不仅能避免重复输入,还能隐藏不必要的细节,提升代码可读性。例如, mysql_fetch_object 函数…

作者头像 李华
网站建设 2026/4/19 1:19:44

19、数据库设计与数据分类全解析

数据库设计与数据分类全解析 数据库索引与完整性规则 在数据库设计过程中,索引的构建是提升查询效率的关键环节。我们为 fine 表创建了索引,如 CREATE INDEX index15 ON fine (card_id_number); 以及 CREATE INDEX index16 ON fine (card_id_number, paid_date); 。其…

作者头像 李华