一、Hash应用场景
- 存储一个用户信息(存储一个对象)
- 可以对某个字段进行自减/自增 一个数!!!
- 为什么不用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