Hash数据结构即数据存储为field、value的格式存储,支持针对指定的field所对应的value操作。
当哈希类型元素个数小于512个同时所有值都小于64字节时,Redis会使用ziplist作为 哈希的内部实现,ziplist使用更加紧凑的结构实现多个元素的连续存储,因此在节省内存方面比hashtable更加优秀。
当 哈希类型无法满足ziplist的条件时,Redis会使用hashtable作为哈希的内部实现,因为此时ziplist的读写效率会下降,而hashtable的读写时间复杂度 为 O(1)。
Hash的操作命令如下:
HSET
将哈希表 hash 中域 ff 的值设置为 vv 。
如果给定的哈希表并不存在, 那么一个新的哈希表将被创建并执行 HSET 操作。
如果域 ff 已经存在于哈希表中, 那么它的旧值将被新值 vv 覆盖。
HSETNX
当且仅当域 ff 尚未存在于哈希表的情况下, 将它的值设置为 vv 。
如果给定域已经存在于哈希表当中, 那么命令将放弃执行设置操作。
如果哈希表 hash 不存在, 那么一个新的哈希表将被创建并执行 HSETNX 命令。
HGET
HGET 命令在默认情况下返回给定域的值。
如果给定域不存在于哈希表中, 又或者给定的哈希表并不存在, 那