Redis 之哈希
命令
hset key field value 设置值,成功返回1,失败返回0,hash提供了 hsetnx 命令 只有key不存在才会设置成功
hget key value 获取值
hdel key field [field ...] 删除filed,返回删除成功的个数
hlen key 统计field个数
hmget key field [field ...] 批量获取field value
hmset key field value [field value ...] 批量设置field value
hexists key field 判断field是否存在,存在返回1,否则返回0
hkeys key 这里是获取key下所有的field
hvals key 获取所有的value
hgetall key 获取所有的feld-value 慎用,使用不当可能阻塞Redis
hincrby key field increment 与incrby key increment 类似
hincrbyfloat by key field increment 与incrbyfloat key increment 类似
hstrlen key field 计算value字符串的长度
内部编码
哈希类型内部的编码实现有两种
- ziplist 压缩列表:当哈希类型元素个数小于hash-max-ziplist-entries配置(默认512个)、同时所有值都小于hash-max-ziplist-value的配置(默认64字节)时,Redis会使用自ziplist实现。ziplist使用更加紧凑的结构实现多个元素的连续存储,比hashtable实现节省内存。
- hashtable(哈希表):当哈希类型无法满足ziplist的条件时,Redis使用hashtable实现,hashtable的读写时间复杂度O(1)。
查看Redis配置命令 config get key 如下:
127.0.0.1:6379> config get hash-max-ziplist-entries 1) "hash-max-ziplist-entries" 2) "512" 127.0.0.1:6379> config get hash-max-ziplist-value 1) "hash-max-ziplist-value" 2) "64"
操作验证:
127.0.0.1:6379> hset ziplistKey ziplist ziplist (integer) 1 127.0.0.1:6379> object encoding ziplistKey "ziplist" 127.0.0.1:6379> hset hashtableKey hashtable 一个汉字三个字节所以使用汉字来填充填充填充填充填充填充填充填充 (integer) 1 127.0.0.1:6379> object encoding hashtableKey "hashtable"