1.hash常用操作
这里还是要强调,redis的类型指的是value的类型。故而这里的hash是把key这一层组织完成以后,到了value这一层,value的其中一种类型还可以是hash。
1.1 HSET 和 HGET
HSET:设置hash类型的key
HSET key field value [field value ...]
返回值是设置成功的键值对(field-value)的个数
HGET:获取对应key中对应field的值
HGET key field
返回值为查询key中对应的field对应的value,如果不存在则返回nil
1.2 HDEL
HDEL:删除hash中指定的字段
注意:del删除的key而hdel删除的field
HDEL key field [field ...]
返回值为本次操作删除的字段个数
1.3 HKEYS
HKEYS:这个操作,先根据key找到对应的value(hash),然后再遍历value
HKEYS key
返回值就是这个key中所有的field
我上面这个操作存在一定的风险,就类似于之前的keys * ,如果key中的hash存在大量的field就有可能让我们的redis阻塞住。
1.4 HVALS
HVALS:和hkeys相对能够获取到hash中的所有value
HVALS key
返回值就是对应key中的所有field对应的值
1.5 HGETALL
HGETALL:查询value中的所有数据
HGETALL key
返回值就是value中的所有数据包括field和value
其实上面这样的操作风险还是有亿点大的,多数情况下,不需要查询所有的field,可能只需要查其中的几个field
1.6 HLEN
HLEN:获取hash的元素个数,不需要遍历
HLEN key
返回值就是hash的长度
1.7 HSETNX
HSETNX:类似于setnx。不存在的时候,才能设置成功,如果存在则失败。
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的应用