Hash

介绍

Hash 是一个键值对(key-value)集合,其中value的形式如:value=[{field1,value1},...{fieldN,valueN}] 。Hash特别适合用于存储对象。

Hash与stirng的区别如下:

uid:1:nametom
uid:1:age23
uid:1nametom
age23

内部实现

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

  • 如果哈希类型元素个数小于512 个(默认值,可由hash-max-ziplist-entries 配置),所有值小于64 字节(默认值,可由hash-max-ziplist-value 配置)的话,Redis会使用压缩列表作为Hash类型的底层数据结构;
  • 如果哈希类型元素不满足上面条件,Redis会使用哈希表作为Hash类型的底层数据结构

在Redis7.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,属性,值)的结构相似,也可以用来存储对象

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

uidnameage
1Tom13
2Jery12

我们可以使用如下命令将用户对象信息存储到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 存储器结构如下:

uid:1nametom
age23
uid:2nametom
age23

在介绍 String 类型的应用场景时有所介绍,String + Json也是存储对象的一种方式,那么存储对象时,到底用 String + json 还是用 Hash 呢?

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

购物车

以用户 id 为 key,商品 id 为 field,商品数量为 value,恰好构成了购物车的3个要素,如下图所示。

涉及的命令如下:

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

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

Last modification:May 31, 2024
如果觉得我的文章对你有用,请收藏本站