Redis Hash
Redis 的字典使用哈希表作为底层实现,一个哈希表里可以有多个哈希表节点。每个哈希表节点就保存了字典中的一个键值对。
Hash是一个string 类型的field和value的映射表。Hash特别适合存储对象,相对于将对象的每个字段存成单个string 类型。一个对象存储在Hash类型中会占用更少的内存,并且可以更方便的存取整个对象。
Hash 常用操作
HSET key field value//存储一个哈希表key的键值
HSETNX key field value//存储一个不存在的哈希表key的键值
HMSET key field value [field value ...] //在一个哈希表key中存储多个键值对
HGET key field//获取哈希表key对应的field键值
HMGET key field [field ...]//批量获取哈希表key中多个field键值
HDEL key field [field ...]//删除哈希表key中的field键值
HLEN key//返回哈希表key中field的数量
HGETALL key//返回哈希表key中所有的键值
HINCRBY key field increment//为哈希表key中field键的值加上增量increment
应用场景
- 对象缓存
结合HASH结构的key-field-value的特性,类似于Java中的HashMap,内部也是“key-value”的形式,field刚好可以存对象的属性名,有如下数据
id | name | score |
---|---|---|
1 | 小明 | 89 |
2 | 小三 | 99 |
我们可以用HMSET命令批量设置field-value,前面拼接用户的ID保证存多个用户的数据不会重复;HMGET批量获取field;MSET修改某一个field。
HMSET mark {userId}:name 小明 {userId}:score 89
HMSET mark 1:name 小明 1:score 89
HMSET mark 2:name 小三 2:score 92
HMGET mark 1:name 1:score
对象与HSAH的关系如下图所示
- 购物车
以用户id为key,商品id为field,商品数量为value可以实现购物车的常规操作。
#添加商品
hset cart:10001 50005 1
#给某一个商品增加数量
hincrby cart:10001 50005 1
#购物车中商品总个数
hlen cart:10001
#删除商品
hdel cart:10001 50005
#获取购物车所有商品
hgetall cart:10001
下图显示了购物几个常用操作可以如何用Redis实现
Hash结构优缺点
优点
- 将同类数据归类整合储存(同一个key),方便数据管理
- 相比String操作,对内存与cpu的消耗更小
- 相比String储存更节省空间
缺点
- 过期功能不能使用在field上,只能用在key上
- Redis集群架构下不适合大规模使用