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

  • 时间:
  • 浏览:2
  • 来源:5分排列5_5分排列3

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

  

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

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

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

  有某种存储法律依据的对比如下表所示。

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

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

效率 很高 高

容量 低 低

灵活性 低 高

序列化 简单 冗杂

  当对象的某个属性时要频繁修改时,不适合用string+json,可能它欠缺灵活,每次修改都时要重新将整个对象序列化并赋值,可能使用hash类型,则还不必 针对某个属性单独修改,越来越 序列化,统统时要修改整个对象。比如,商品的价格、销量、关注数、评价数等可能时不时发生变化的属性,就适合存储在hash类型里。

  在介绍string类型的应用场景时有所介绍,string + json也是存储对象的有某种法律依据,越来越 存储对象时,到底用string + json还是用hash呢?

  hash类型的(key, field, value)的社会形态与对象的(对象id, 属性, 值)的社会形态类式,也还不必 用来存储对象。

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

  当然,不常变化的属性存储在hash类型里也越来越 什么的什么的问题,比如商品名称、商品描述、上市日期等。或者 ,当对象的某个属性全部都是基本类型或字符串时,使用hash类型就时要手动进行冗杂序列化,比如,商品的标签是曾经标签对象的列表,商品可领取的优惠券是曾经优惠券对象的列表(如下图所示)等,即使以coupons(优惠券)作为field,value想存储优惠券对象列表也还是要使用json来序列化,曾经 一段话序列化工作就太繁琐了,不如直接用string + json的法律依据存储商品信息来的简单。

  1. 购物车

  2. 存储对象