Redis 哈希对象和集合对象

哈希对象

哈希对象编码实现为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).

常用操作

在这里插入图片描述

发布了79 篇原创文章 · 获赞 3 · 访问量 5248

猜你喜欢

转载自blog.csdn.net/SW_LCC/article/details/103267749