码迷,mamicode.com
首页 > 其他好文 > 详细

REDIS HGETALL按序输出结果

时间:2019-01-29 12:00:55      阅读:376      评论:0      收藏:0      [点我收藏+]

标签:ble   哈希表   val   列表   server   现在   商品数据   默认值   格式   

今天在项目中使用Redis的hash结构存一些商品数据,存的时候是按照商品id从小到大放进去的。然后现在想hgetAll着取出来,也能够按照id顺序再取出来,但是发现结果并不是这样的,输出是乱序的。
随决定看一下到底是为啥,发现了猫腻。

《REDIS设计与实现》中指出,

创建空白哈希表时, 程序默认使用 REDIS_ENCODING_ZIPLIST 编码, 当以下任何一个条件被满足时, 程序将编码从 REDIS_ENCODING_ZIPLIST 切换为 REDIS_ENCODING_HT :

哈希表中某个键或某个值的长度大于 server.hash_max_ziplist_value (默认值为 64 )。
压缩列表中的节点数量大于 server.hash_max_ziplist_entries (默认值为 512 )。

然后看了看自己的数据,发现值的长度大于64了,因此采用了hashtable的编码格式。是无序的。

REDIS HGETALL按序输出结果

标签:ble   哈希表   val   列表   server   现在   商品数据   默认值   格式   

原文地址:http://blog.51cto.com/fulin0532/2347485

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!