前言
是的,我又来了。这篇文章主要解析一下 Set 这个数据结构,也是 Redis 系列的第七篇了。也不知道好哥哥们过得好不好,冷不冷(广州一夜间从夏天进入了冬天),有没有背着我偷懒,偷懒的都是渣男(诶诶诶,能不能只动嘴,不动手)。
写这玩意真的挺累的,我的脖子已经动不了了(可能不是写博客造成的,也可能是落枕,主要想骗 bebebe...)。这已经很明显了吧,好哥哥们,赶紧关注加点赞呀。
好哥哥们还是要坚持手敲哦,别偷这个懒。 好了,让我们继续冲吧,冲冲冲......
概述
Set 类型也是用来保存多个的字符串元素,但和列表(List)类型不一样的是,集合中不允许有重复元素,并且集合中的元素是无序的,不能通过索引下标获取元素。还记得 JAVA (别怪我只用 JAVA 举例,其他的我也不会呀)中的 Set 吗,是不是也是这样的呢?好哥哥们,看图说话(请叫我灵魂画手)。
1 命令
1.1 集合内操作
1.1.1 添加元素
## 添加元素
sadd key element [element ...]
## 向myset中添加 abc,返回的是是成功添加元素的个数
sadd myset a b c
1.1.2 删除元素
## 格式 可以指定多个
srem key element [element ...]
## 删除myset中的ab,返回的是成功删除的个数
srem myset a b
1.1.3 统计元素个数
## 格式,scard的时间复杂度为O(1),它不会遍历集合所有元素,而是直接用Redis内部的变量
scard key
## 返回myset的元素个数
scard myset
1.1.4 判断元素是否在集合中
## 格式
sismember key element
## 在就返回1否则返回0
sismember myset c
1.1.5 随机从集合返回指定个数元素
## 格式,[count]是可选参数,如果不写默认为1
srandmember key [count]
## 随机返回myset中的两个元素
srandmember myset 2
1.1.6 从集合随机弹出元素
## 格式,srandmember和spop都是随机从集合选出元素,两者不同的是spop命令执行后,元素会从集合中删除,而srandmember不会。
spop key
## 从myset随机删除一个
spop myset
1.1.7 获取所有元素
## 格式
smembers key
## 返回myset中的所有元素,需要注意的是结果是无序的
smembers myset
1.2 集合间操作
先设置两个集合。user:1:tag 和 user:2:tag,通过 sadd 添加元素。
## user:1:tag
sadd user:1:tag sunny cute handsome
## user:2:tag
sadd user:2:tag beefcake cute sunny
1.2.1 求多个集合的交集
## 格式
sinter key [key ...]
## 取user:1:tag user:2:tag的交集,结果返回sunny和cute
sinter user:1:tag user:2:tag
1.2.2 求多个集合的并集
## 格式
suinon key [key ...]
## 取user:1:tag user:2:tag的并集,结果返回sunny cute handsome beefcake
suinon user:1:tag user:2:tag
1.2.3 求多个集合的差集
## 格式
sdiff key [key ...]
## 取user:1:tag user:2:tag的差集,结果返回handsome beefcake
sdiff user:1:tag user:2:tag
2 时间复杂度
看图不说话系列
3 使用场景
- 给用户添加标签,跟我们上面的例子一样。一个人对应多个不同的标签。
- 好友/关注/粉丝/感兴趣的人集合,可以使用上面的取交集、并集相关的命令。
- 随机展示,通过 srandmember 随机返回对应的内容,像一些首页获取动态内容可以这么玩。
- 黑名单/白名单,有业务出于安全性方面的考虑,需要设置用户黑名单、ip 黑名单、设备黑名单等,set 类型适合存储这些黑名单数据,sismember 命令可用于判断用户、ip、设备是否处于黑名单之中。
本期就到这啦,有不对的地方欢迎好哥哥们评论区留言,另外