redis 中的hashtable

 

                                          Redis中的hash

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 key field value 设置 hash field 为指定值,如果 key 不存在,则创建

hget key field 获取指定的 hash field。

hmget key filed1....fieldN 获取全部指定的 hash filed。

hmset key filed1 value1 ...... filedN valueN同时设置 hash 的多个 field。

hincrby key field integer 将指定的 hash filed 加上指定值。成功返回 hash filed 变更后的值。

hexists key field 检测指定 field 是否存在。

hdel key field 删除指定的 hash field。

hlen key 返回指定 hash 的 field 数量。

shkeys key 返回 hash 的所有 field。

hvals key 返回 hash 的所有 value。

hgetall 返回 hash 的所有 filed 和 value

猜你喜欢

转载自blog.csdn.net/u014660247/article/details/78226412