Redis 哈希对象和集合对象

本文详细介绍了Redis中哈希对象的两种编码方式:ziplist和hashtable,以及它们之间的转换条件。哈希对象在ziplist编码下,键值对按特定顺序存储;当不满足条件时,转换为hashtable编码。接着讨论了集合对象,同样有intset和hashtable两种编码,转换规则和哈希对象类似。最后提到了有序集合对象,其可以使用ziplist或skiplist编码,skiplist结合字典以提高性能。

哈希对象

哈希对象编码实现为ziplist或hashtable

ziplist

ziplist作为哈希对象底层实现时,当有新兼职加入哈希对象,则会保存键的列表节点放到表尾,再兑入值得列表节点。
即保存同一键值对节点总是相邻,保存键的节点在前,保存值的节点在后。
先添加到哈希对象中的键值对会放在列表表尾。
使用ziplist编码的哈希对象,属性如下:
在这里插入图片描述

hashtable

使用hashtable编码的哈希对象,每个键值对都用字典键值对保存。
其中字典的键,值都是字符串对象。
示例:
在这里插入图片描述

编码转换

当哈希对象处于如下条件时,使用ziplist编码:
1.所有键值对的键 ,值字符串长度都小于64字节(hash-max-ziplist-value)。
2.保存键值对数量小于512个(hash-max-ziplist-entris)。
若不能满足如上条件,则使用hashtable编码。

正在使用ziplist编码的哈希对象,如果新加进来的键值对象键,值长度大于等于64或者存储的数量超过512,则会导致编码转换。从ziplist编码转为hashtable编码。
哈希对象操作命令:
在这里插入图片描述

集合对象

集合对象编码为intset(整数集合)和hashtable
使用示例:

SADD nums 1 3 5

对象属性如下:
在这里插入图片描述
此nums对象使用intset编码 。

SADD fruits"apple" "banana" "cherry"

对象属性如下:
在这里插入图片描述
此对象使用hashtable编码。

集合对象编码转换

当满足如下条件时,使用intset编码,否则使用hashtable编码:

1.所有元素都是整数值
2.保存对象不超过512个(set-max-intset-entris)

集合对象常用操作

在这里插入图片描述

有序集合对象

有序集合对象编码为ziplist或skiplist

ziplist

使用ziplist编码作为底层实现,集合元素使用相邻的压缩列表节点保存,第一个节点保存成员,第二个保存分值。列表内元素按分值从小到大排序,小的靠近对头,大的靠近队尾。
集合对象属性如下:
在这里插入图片描述

skiplist

使用skiplist作为底层实现,元素按分值从小到大保存所有集合元素,每个节点保存一个集合元素,其中object属性保存元素成员,score属性保存分值。
有序集合对象使用skiplist编码,实际上用到的是skiplist和字典。同时使用这两种结构即提高性能,而字典和跳跃表会共享元素成员和分值,也不会造成内存损失。
示例:

SADD price 8.5 apple 5.0 banana 6.0 cherry

属性:
在这里插入图片描述
底层数据结构:
在这里插入图片描述

编码转换

zipllist编码的使用条件:
1.元素小于128个(zset-max-ziplist-entries)
2.所有成员字节小于64字节(zset-max-ziplist-value).

常用操作

在这里插入图片描述

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值