介绍

Hash(哈希、散列)是键值对集合,形式如: value={ field1: value1, field2: value2, ... }

Hash 特别适合用于存储对象,与 String 的区别:

内部实现

Hash 类型的底层数据结构是由压缩列表哈希表实现的:

  • 如果哈希类型元素个数小于 512 个(默认值,可由 hash-max-ziplist-entries 配置),所有值小于 64 字节(默认值,可由 hash-max-ziplist-value 配置),使用压缩列表
  • 否则,使用哈希表

在 Redis 7.0 中,压缩列表数据结构被废弃,交由 listpack 数据结构来实现

常用命令

# 存储一个哈希表 key 的键值
HSET key field value
# 获取哈希表 key 对应的 field 键值
HGET key field
 
# 在一个哈希表 key 中存储多个键值对
HMSET key field value [field value ...]
# 批量获取哈希表 key 中多个 field 键值
HMGET key field [field ...]
# 批量删除哈希表 key 中的 field 键值
HDEL key field [field ...]
 
# 返回哈希表 key 中 field 的数量
HLEN key
# 返回哈希表 key中 所有的键值
HGETALL key
 
# 为哈希表 key 中 field 键的值加上增量 n
HINCRBY key field n

应用场景

存储对象

Hash 类型的 (key, field, value) 的结构与对象的 (对象 id, 属性, 值) 的结构相似,可以用来存储对象

以用户信息为例,它在关系型数据库中的结构是这样的:

将其存储到 Hash 类型:

# 存储一个哈希表 uid:1 的键值
> HMSET uid:1 name Tom age 15
2
 
# 存储一个哈希表 uid:2 的键值
> HMSET uid:2 name Jerry age 13
2
 
# 获取哈希表用户 id 为 1 中所有的键值
> HGETALL uid:1
1) "name"
2) "Tom"
3) "age"
4) "15"

Redis Hash 存储其结构:

与 String 存储对象相比

一般对象用 String + Json 存储,对象中某些频繁索引或变化的属性可以考虑抽出来用 Hash 类型存储

购物车

以用户 id 为 key,商品 id 为 field,商品数量为 value

  • 添加商品:HSET cart:{用户id} {商品id} 1
  • 添加数量:HINCRBY cart:{用户id} {商品id} 1
  • 商品总数:HLEN cart:{用户id}
  • 删除商品:HDEL cart:{用户id} {商品id}
  • 获取购物车所有商品:HGETALL cart:{用户id}

当前仅仅是将商品 id 存储到了 Redis 中,在回显商品具体信息时,还需要拿着商品 id 查询一次数据库,获取完整的商品的信息