redis-hashes 类型及操作

时间:2016-11-17 14:37:21 阅读:540次
redis-hashes 类型及操作

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 字节



hset key field value

hsetnx key field value 

hmset key field value [field value ...] 同时设置hash 的多个field。

hget key field 获取指定的hash filed。

hmget key field [field ...] 获取全部指定的hash filed。

hincrby key field increment 指定的hash filed 加上给定值。

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

hlen key 返回指定hash 的field 数量

hdel key field [field] 删除指定的field,并返回删除的数量.

hkeys key 返回hash 的所有field。

hvals key 返回hash 的所有value。

hgetall 获取某个hash 中全部的filed 及value。


扫描二维码关注程序员爱笔记,接收更多资讯

评论

快速评论