redis中hash的应用场景

一、先懂 Hash 是什么

Hash 结构:key → field → value类比:

  • String 是:一个 key 只能存一个值
  • Hash 是:一个 key 里面可以存很多小字段

适合存一个对象的多个属性,不用像 String 那样整存整取 JSON。


二、Hash 最核心应用场景

1. 存储用户信息(最经典)

比如用户:id、姓名、年龄、手机号、头像、性别

如果用 String:要把整个对象转 JSON,改个年龄也要全量取出、改完再全量存,浪费性能。

用 Hash:

plaintext

复制代码
key:user:1001
field: name   value: 张三
field: age    value: 22
field: phone  value: 13800138000

优点:

  • 只改某个字段,不用动整个对象
  • 按需取字段,不用一次性拿全部数据

命令示例:

redis

复制代码
hset user:1001 name 张三 age 22
hget user:1001 name
hgetall user:1001

2. 商品信息缓存

商品标题、价格、库存、销量、简介一个商品对应一个 Hash,单独改价格、库存非常方便


3. 购物车场景

结构设计:

  • key:cart:用户id
  • field:商品 id
  • value:购买数量

plaintext

复制代码
cart:2001
10001 → 2件
10002 → 1件

增、删、改商品数量都极其方便,不用序列化 JSON。


4. 系统配置、权限配置

比如角色权限、网站配置、模块开关一个 key 下多个配置字段,单独修改某一项配置。


5. 直播间 / 房间在线信息

在线人数、主播状态、房间热度分开字段维护,更新粒度小、性能高。


三、Hash 和 String 怎么选

  • 整个对象经常一起查、很少单独改字段 → 用 String 存 JSON
  • 经常只修改对象里某一个字段 → 用 Hash

四、总结

Redis Hash 适用场景:用户信息缓存、商品信息缓存、购物车、系统配置、直播间属性存储 ;优势是按字段读写、局部更新、节省内存和网络开销,不用整存整取。

相关推荐
小马爱打代码5 小时前
Redis 集群方案详解:主从复制、哨兵、脑裂、分片集群和哈希槽
数据库·redis·哈希算法
海南java第二人7 小时前
ClickHouse 稀疏索引深度解析:为什么 OLAP 数据库不用 B-Tree?
数据库·clickhouse
Litluecat7 小时前
信创迁移:Oracle切换海量数据库,慢sql扫描
数据库·sql·oracle·信创·海量
消失在人海中7 小时前
Oracle的CURRENT REDO丢失,数据丢失风险分析
数据库·oracle
喵了几个咪8 小时前
选择第三方IAM还是自建权限体系?中小型后台系统权限架构决策指南
数据库·oracle·架构
Elastic 中国社区官方博客9 小时前
Kibana:使用 AI Chat 及 MCP 轻松创建 AI 原生仪表板
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·信息可视化
杨云龙UP9 小时前
Oracle Health Check巡检脚本使用SOP V2.0:从HTML原始报告→生成Word专业巡检报告→交付客户_2026-06-03
linux·运维·数据库·sql·oracle·报告·巡检
Database_Cool_10 小时前
Hudi 湖仓一体架构:阿里云 AnalyticDB MySQL 原生集成最佳实践
数据库·mysql·阿里云
我是一颗柠檬10 小时前
【Redis】发布订阅与消息队列Day8(2026年)
数据库·redis·后端·缓存