Redis 学习(十一)集合(Set)

Redis 的 Set 是 String 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。

Redis 中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。

集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

实例

redis 127.0.0.1:6379> SADD runoobkey redis
(integer) 1
redis 127.0.0.1:6379> SADD runoobkey mongodb
(integer) 1
redis 127.0.0.1:6379> SADD runoobkey mysql
(integer) 1
redis 127.0.0.1:6379> SADD runoobkey mysql
(integer) 0
redis 127.0.0.1:6379> SMEMBERS runoobkey

1) "mysql"
2) "mongodb"
3) "redis"

在以上实例中我们通过 SADD 命令向名为 runoobkey 的集合插入的三个元素。


Redis 集合命令

下表列出了 Redis 集合基本命令:

 

序号命令及描述
1 SADD key member1 [member2]
向集合添加一个或多个成员
2 SCARD key
获取集合的成员数
3 SDIFF key1 [key2]
返回给定所有集合的差集
4 SDIFFSTORE destination key1 [key2]
返回给定所有集合的差集并存储在 destination 中
5 SINTER key1 [key2]
返回给定所有集合的交集
6 SINTERSTORE destination key1 [key2]
返回给定所有集合的交集并存储在 destination 中
7 SISMEMBER key member
判断 member 元素是否是集合 key 的成员
8 SMEMBERS key
返回集合中的所有成员
9 SMOVE source destination member
将 member 元素从 source 集合移动到 destination 集合
10 SPOP key
移除并返回集合中的一个随机元素
11 SRANDMEMBER key [count]
返回集合中一个或多个随机数
12 SREM key member1 [member2]
移除集合中一个或多个成员
13 SUNION key1 [key2]
返回所有给定集合的并集
14 SUNIONSTORE destination key1 [key2]
所有给定集合的并集存储在 destination 集合中
15 SSCAN key cursor [MATCH pattern] [COUNT count]
迭代集合中的元素
# 判断在集合中的是否存在
sismember p985  rd

 

 

 

 

set型应用场景:


1.动态访问黑名单

 

例如服务器中要设置 用于访问控制的黑名单,如果直接将黑名单写入服务器的配置文件,那么存在的问题是,无法动态修改黑名单。此时可以将黑名单直接写入redis中,只要有客户端来访问服务器,服务器在获取到客户端ip后先从redis的黑名单中查看是否存在该IP,如果存在则拒绝访问,否则访问通过。

2.有限随机数

有限随机数指的是返回的随机数基于某一个集合范围内的随机数,例如抽奖、随机选人,通过spop或者srangmember可以实现从指定集合中随机选出元素。

3.用户画像。

社交平台、电商平台等各种需要用户注册登录的平台,会根据用户提供的资料和用户使用习惯,为每个用户随机进行画像,即为每个用户定义很多可以反应用户特征的标签,这些标签就可以使用sadd添加到该用户对应的集合中,这些标签具有无序、不重复特征。

同时平台还可以使用sinter/sinterstore根据用户画像问的交集进行好友推荐、商品推荐、客户推荐等。

 

 

 

 

 

 

 

 


 

 


 

 


 

 

 


 

 


 

 


 

 


 


 

 



 

 



 

 



 

posted @ 2020-03-09 23:25  King-DA  阅读(145)  评论(0编辑  收藏  举报