REDISHGETALL按序输出结果

今天在项目中使用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的编码格式。是无序的。


当前名称:REDISHGETALL按序输出结果
文章源于:http://www.hxwzsj.com/article/jgpejh.html

其他资讯

Copyright © 2025 青羊区翔捷宏鑫字牌设计制作工作室(个体工商户) All Rights Reserved 蜀ICP备2025123194号-14
友情链接: 手机网站建设 成都网站设计制作公司 成都商城网站建设 重庆电商网站建设 响应式网站设计 成都网站建设公司 专业网站建设 成都模版网站建设 品牌网站建设 网站制作 营销型网站建设 网站建设费用 高端品牌网站建设 自适应网站设计 手机网站制作 成都做网站建设公司 LED网站设计方案 重庆网站建设 网站设计公司 成都企业网站建设公司 重庆网站建设 网站设计