简介
redis集合(set)类型和list列表类型类似,都可以用来存储多个字符串元素的集合。但是和list不同的是set集合当中不允许重复的元素。而且set集合当中元素是没有顺序的,不存在元素下标。
redis的set类型是使用哈希表构造的,因此复杂度是O(1),它支持集合内的增删改查,并且支持多个集合间的交集、并集、差集操作。可以利用这些集合操作,解决程序开发过程当中很多数据集合间的问题。
Set数据类型的内部编码
Intset(整数集合):当集合元素个数小于set-max-ziplist-entries配置(默认512个),redis会使用intset作为集合的内部实现来减少内存的使用
Hashtable(哈希表):当集合类型无法满足intset的条件时,redis会使用hashtable作为集合的内部实现
常用命令
sadd
sadd key member [member ...]
将一个或者多个元素假如到集合当中,假如加入的元素已经存在在集合当中,则不会添加。假如
key不存在,则直接增加一个key,并加入元素
smembers
smembers key
返回集合中的所有的成员。
scard
scard key
返回集合中元素的个数。
sismember
sismember key member
判断指定的值是否是集合的成员,假如不是集合的成员,或 key 不存在,返回 0。
srem
srem key member
用于移除集合元素中一个或者多个元素,假如要移除的元素不存在,默认不处理。
sinter
sinter key [key ...]
返回给定所有给定集合的交集。 不存在的集合 key 被视为空集。 当给定集合当中有一个空集
时,结果也为空集。
sdiff
sdiff key [key ...]
返回指定集合之间的差集。
Sunion
sunion key [key ...]
返回给定集合的并集。同理,不存在的集合 key 被视为空集。
Sscan
sscan key cursor [match pattern]
用于迭代集合中元素,取出匹配条件的元素
0 表示从集合的第一个元素开始匹配。
应用场景
抽奖
相关命令:sRandMember、sPop
sRandMember不会从集合中删除返回的元素
sPop会删除从集合中返回的元素
比如,集合中有100个元素,值从数字1到数字100.我们定义抽到的是数字1的话,即表示中奖。 使用sRandMember的话,不管之前抽过多少次,下次抽中的概率都是1%。而使用sPop的话,则每次抽中的概率都不一样。第一个人抽中概率是1%,当第一个人没抽中的话,第二个人抽中概率就是1/99,以此类推。