一、简单描述3d
hash是一个string类型的field和value的映射表。添加和删除操做都是O(1)(平均)的复杂度。hash类型特别适合用于存储对象。在field的数量在限制的范围内以及value的长度小于指定的字节数,那么此时的hash类型是用zipmap存储的,因此会比较节省内存。能够在配置文件里面修改配置项来控制field的数量和value的字节数大小。对象
hash-max-zipmap-entries 512 #配置字段最多512个blog
hash-max-zipmap-value 64 #配置value最大为64字节。ip
必须知足以上两个条件,那么该key会被压缩。不然就是按照正常的hash结构来存储hash类型的key。内存
【注意】这两个配置并非限制hash结构最多只能存多少个field以及value的最大字节数,而是说在field未超过配置的数量,并且每个filed对应的value的长度都小于指定的字节数时,注意是两个条件都知足时,该key的存储是采用的zipmap,就是压缩了的数据,节省空间。当field的数量超过了,或者其中有value的长度大于指定的长度,那么整个key就会采用正常的hash结构来在内存中存储。get
二、相关命令(基于4.0.1版本)string
1)hset命令:设置一个key的filed对应的值,filed不存在则新增,field存在则修改field对应的值。hash
2)hgetall命令:获取该key的全部field以及对应的值。配置
3)hlen命令:获取key的长度,就是field的个数。file
4)hvals命令:获取全部filed对应的value,只返回value。
5)hkeys命令:获取全部的filed,只返回filed,不返回value。
6)hmset命令:一次设置多个filed和对应的值
7)hmget命令:获取多个filed的值
8)hdel命令:删除filed,容许删除多个。
9)hincrby命令:给filed字段的值增长一个数,能够是负数。
【注意】不能增长浮点数
10)hexists命令:判断某个field是否存在,存在则返回1,不然返回0。
三、小结
1)hash结构是能够压缩的,要同时知足2个条件,也就是两个配置项;
2)根据需求来肯定数据是采用string类型来存储(好比把对象序列化为string类型),仍是说使用hash存储(把对象的属性化为field和value来存储),若是是field比较少的,并且value也比较小,那么用hash节省内存。可是也要考虑具体的需求,若是采用hash,同时要更新几个field时会不会麻烦些,若是采用string类型,直接修改整个对象而后直接序列化。
固然hash也支持直接把对象序列化来存储。具体问题具体分析。