Redis基础(4):Set类型和SortedSet类型

0 阅读2分钟

Set类型

RedisSet类型和Java中的HashSet类似,可以看作是一个ValuenullHashMap。因为其也是一个Hash表,所以说具备和HashSet相似的特征:元素无序存储、元素不可重复、查找效率高、支持交、并、差集等集合运算

image.png
上图是Set类型的常用命令,是基本的命令,只涉及到单个Set的操作

image.png
这张图是Set之间的运算命令,也就是不同Set进行集合运算的命令,集合之间的运算关系如图所示:

image.png
图中两个Set的并集(SUNION)是A、B、C、D需要注意的是Set中的元素是不可以重复的,在单个Set操作时,如果Sadd的元素重复将插入失败;在Set间进行运算时,会自动去重。

SortedSet类型

RedisSortedSet是一个可排序的Set集合,和Java中的TreeSet类似,但底层的数据结构差别很大SortedSet中的每一个元素都带有一个Score属性,可以基于Score属性对元素进行排序,其底层的是实现是一个跳表(SkipList)加一个Hash表SortedSet具备这些特性:元素之间可排序、元素之间不重复、查询效率高,由于SortedSet天生自带可排序的特性,所以说经常用于实现排行榜这样的功能。

image.png
上图是SrotedSet的常用命令,在使用SortedSet类型的时候需要注意:每一个元素都需要一个Score属性,而Score属性也正是SortedSet用于排序的依据。并且SortedSet在排序时默认是升序排列的,如果想要获取降序排列的结果,可以在命令开头的Z后面添加REV(Reverse)来代表降序排列。在使用SortedSet时需要注意到底是需要获取分数区间的元素个数还是要获取分数区间的具体元素