今天在项目中使用复述的散列结构存一些商品数据,存的时候是按照商品id从小到大放进去的。然后现在想hgetAll着取出来,也能够按照id顺序再取出来,但是发现结果并不是这样的,输出是乱序的。
随决定看一下到底是为啥,发现了猫腻。
《复述,设计与实现》中指出,
创建空白哈希表时,程序默认使用REDIS_ENCODING_ZIPLIST编码,当以下任何一个条件被满足时,程序将编码从REDIS_ENCODING_ZIPLIST切换为REDIS_ENCODING_HT:
哈希表中某个键或某个值的长度大于服务器。hash_max_ziplist_value(默认值为64年)。
引用>
压缩列表中的节点数量大于服务器。hash_max_ziplist_entries(默认值为512年)。然后看了看自己的数据,发现值的长度大于64了,因此采用了哈希表的编码格式。是无序的。
复述,HGETALL按序输出结果