hash类型的应用场景 —— Redis实战经验

  • 时间:
  • 浏览:1

  在介绍string类型的应用场景时有所介绍,string + json也是存储对象的有一种法子,没法存储对象时,到底用string + json还是用hash呢?

  2. 存储对象

  hash类型是一2个 string类型的field和value的映射表,每个 hash 还可不可以存储 232 - 1 键值对(40多亿),hash类型主要有以下应用场景。

  加入string类型的应用场景后的思维导图如下。

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

hash类型的应用场景 —— Redis实战经验

  

时延 很高 高

容量 低 低

灵活性 低 高

序列化 简单 僵化

  当对象的某个属性时要频繁修改时,不适合用string+json,可能性它过高 灵活,每次修改都时要重新将整个对象序列化并赋值,可能性使用hash类型,则还可不可以针对某个属性单独修改,没法序列化,很久 时要修改整个对象。比如,商品的价格、销量、关注数、评价数等可能性无缘无故处在变化的属性,就适合存储在hash类型里。

  综上,一般对象用string + json存储,对象中有一种频繁变化的属性抽出来用hash存储。

  1. 购物车

  有一种存储法子的对比如下表所示。

  当然,不常变化的属性存储在hash类型里也没法现象,比如商品名称、商品描述、上市日期等。很久 ,当对象的某个属性有的是基本类型或字符串时,使用hash类型就时要手动进行僵化 序列化,比如,商品的标签是一2个 标签对象的列表,商品可领取的优惠券是一2个 优惠券对象的列表(如下图所示)等,即使以coupons(优惠券)作为field,value想存储优惠券对象列表也还是要使用json来序列化,以前语录序列化工作就太繁琐了,不如直接用string + json的法子存储商品信息来的简单。

  hash类型的(key, field, value)的价值形式与对象的(对象id, 属性, 值)的价值形式类事,也还可不可以用来存储对象。

  原文地址https://www.cnblogs.com/pangzizhe/p/106571001.html

  hash类型的常用命令可参考http://www.runoob.com/redis/redis-hashes.html