1.hash常用操作
这里还是要强调,redis的类型指的是value的类型。故而这里的hash是把key这一层组织完成以后,到了value这一层,value的其中一种类型还可以是hash。
1.1 HSET 和 HGET
HSET:设置hash类型的key
cpp
HSET key field value [field value ...]
返回值是设置成功的键值对(field-value)的个数

HGET:获取对应key中对应field的值
cpp
HGET key field
返回值为查询key中对应的field对应的value,如果不存在则返回nil

1.2 HDEL
HDEL:删除hash中指定的字段
注意:del删除的key而hdel删除的field
cpp
HDEL key field [field ...]
返回值为本次操作删除的字段个数

1.3 HKEYS
HKEYS:这个操作,先根据key找到对应的value(hash),然后再遍历value
cpp
HKEYS key
返回值就是这个key中所有的field

我上面这个操作存在一定的风险,就类似于之前的keys * ,如果key中的hash存在大量的field就有可能让我们的redis阻塞住。
1.4 HVALS
HVALS:和hkeys相对能够获取到hash中的所有value
cpp
HVALS key
返回值就是对应key中的所有field对应的值

1.5 HGETALL
HGETALL:查询value中的所有数据
cpp
HGETALL key
返回值就是value中的所有数据包括field和value

其实上面这样的操作风险还是有亿点大的,多数情况下,不需要查询所有的field,可能只需要查其中的几个field

1.6 HLEN
HLEN:获取hash的元素个数,不需要遍历
cpp
HLEN key
返回值就是hash的长度

1.7 HSETNX
HSETNX:类似于setnx。不存在的时候,才能设置成功,如果存在则失败。
cpp
HSETNX key field value

1.8 常用操作小结
|---------------------------------------|-------------------------|-------|
| 命令 | 执行效果 | 时间复杂度 |
| hset key field value | 设置值 | O(1) |
| hget key field | 获取值 | O(1) |
| hdel key field [field ...] | 删除field | O(k) |
| hlen key | 计算field个数 | O(1) |
| hgetall key | 获取所有的field-value | O(k) |
| hmget field [field ...] | 批量获取field-value | O(k) |
| hmset field value [field value ...] | 批量设置field-value | O(k) |
| hexists key field | 判断field是否存在 | O(1) |
| hkeys key | 获取所有的field | O(k) |
| hvals key | 获取所有的value | O(k) |
| hsetnx key field value | 设置值,但必须再field不存在时才能设置成功 | O(1) |
| hincrbykey field n | 对应field-value + n | O(1) |
| hincrbyfloat key field n | 对应field-value + n | O(1) |
| hstrlen key field | 计算value的字符串长度 | O(1) |
2.redis中的hash的内部编码
rar、zip、gzip、7z...这些是具体的压缩算法
压缩的本质是针对数据进行重新编码。不同的数据,有不同的特点,结合这些特点,进行精妙的设计,重新编码之后,就能缩小体积。类似的例子如下

2.2 ziplist
ziplist存在的目的就是节省空间,ziplist内部的数据结构是精心设计的
使用hash来表示一个普通的hash表,可能会浪费一定的空间(hash首先是一个数组,数组上有些位置有元素,有些没有)

3.redis中的hash的应用


