一、Hash应用场景

  1. 存储一个用户信息(存储一个对象)
  2. 可以对某个字段进行自减/自增 一个数!!!
  3. 为什么不用string存储一个对象?

Hash是最接近关系数据库结构的数据类型,可以将数据库一条记录或程序中的一个对象转换成hashmap存放在Redis中!!!!

 

用户ID为查找的key,存放的value用户包括姓名、年龄、生日等信息,如果用普通的key/value结构来存储,主要有两种方式

  • 将用户ID作为查找的key,把其他信息封装成一个对象以序列化的方式存储(增加了序列化/反序列化的开销,并且在需要修改其中一项信息时候,需要将整个对象取回,并且修改要对并发进行保护,引入CAS等复杂问题!!!

set user:1 {"id":1,"name":"tw","age":"20"}

  • 将用户信息成员存成多少个key-value对儿。用户ID+对应属性的名称作为唯一标识来取得对应属性的值(省去了序列化/反序列化开销和并发问题,但是用户ID为重复存储,内存浪费!!!)

set user:1 1 set user:1:name tw set user:1:age 20