哈希Hash
-
Redis hash 是一个键值对集合。
-
Redis hash 是一个
string
类型的field
和value
的映射表,hash
特别适合用于存储对象。 -
类似
Java
里面的Map<String,Object>
。 -
用户 ID 为查找的 key,存储的 value 用户对象包含姓名,年龄,生日等信息,如果用普通的 key/value 结构来存储,主要有以下 2 种存储方式:
方法一:每次修改用户的某个属性需要先反序列化改好后再序列化回去。开销较大。
方法二:用户 ID 数据冗余。
所以这个时候我们使用以下方法:
方法三:通过 key (用户 ID) + field (属性标签) 就可以操作对应属性数据了,既不需要重复存储数据,也不会带来序列化和并发修改控制的问题。
常用命令
hset <key><field><value>
给<key>
集合中的<field>
键赋值<value>
hget <key1><field>
从<key1>
集合<field>
取出valuehmset <key1><field1><value1><field2><value2>
批量设置hash的值hexists <key1><field>
查看哈希表key中,给定域field是否存在hkeys <key>
列出该hash集合的所有fieldhvals <key>
列出该hash集合的所有valuehincrby <key><field><increment>
为哈希表key中的域field的值加上增量hsetnx <key><field><value>
将哈希表key中的域field的值设置为value,当且仅当域field不存在
数据结构
Hash 类型对应的数据结构是两种:ziplist
(压缩列表),hashtable
(哈希表)。当 field-value
长度较短且个数较少时,使用 ziplist
,否则使用 hashtable
。