Redis hash 是一个 string 类型的 field 和 value 的映射表.它的添加、 删除操作都是 O(1)(平均)。
hash 特别适合用于存储对象。相较于将对象的每个字段存成单个 string 类型。
将一个对象存储在 hash 类型中会占用更少的内存,并且可以更方便的存取整个对象。省内存的原因是新
建一个 hash 对象时开始是用 zipmap(又称为 small hash)来存储的。
这个 zipmap 其实并不是 hash table,但是 zipmap 相比正常的 hash 实现可以节省不少 hash 本身需要的一些元数据存储开销。尽管 zipmap 的添加,删除,查找都是 O(n),但是由于一般对象的 field 数量都不太多。所以使用 zipmap 也是很快的,也就是说添加删除平均还是 O(1)。如果 field 或者 value
的大小超出一定限制后,Redis 会在内部自动将 zipmap 替换成正常的 hash 实现.
这个限制可以在配置文件中指定
hash-max-zipmap-entries 64 #配置字段最多 64 个 hash-max-zipmap-value 512 #配置 value 最大为 512 字节
下面说一下Hash的基本命令:
hset:
设置 hash field 为指定值,如果 key 不存在,则先创建。
hsetnx:
设置 hash field 为指定值,如果 key 不存在,则先创建。如果 field 已经存在,返回 0,nx 是not exist 的意思。
第一次执行是成功的,但第二次执行相同的命令失败,原因是 field 已经存在了。
hmset:
hget:
获取指定的 hash field。
hmget:
不存在的field,会返回nil
hincrby:
hexists:
通过上例可以说明 field2 存在,但 field9 是不存在的。
hlen:
hdel:
删除指定hash的field
hkeys:
hvals:
hgetall:
可见,一下子将 myhash 中所有的 field 及对应的 value 都取出来了。