Redis集合是一个无序的字符串合集。你可以以O(1) 的时间复杂度(无论集合中有多少元素时间复杂度都为常量)完成 添加,删除以及测试元素是否存在的操作。
Redis集合有着不允许相同成员存在的优秀特性。向集合中多次添加同一元素,在集合中最终只会存在一个此元素。实际上这就意味着,在添加元素前,你并不需要事先进行检验此元素是否已经存在的操作。
一个Redis列表十分有趣的事是,它们支持一些服务端的命令从现有的集合出发去进行集合运算。 所以你可以在很短的时间内完成合并(union),求交(intersection), 找出不同元素的操作。
一个集合最多可以包含232-1个元素(4294967295,每个集合超过40亿个元素)。
下面,来列举一个简单的例子:
#我添加一个名为家庭的集合(我和我妻子)
> sadd family biki zhibin
(integer) 2
#显示我的家庭成员列表
> smembers family
1) "biki"
2) "zhibin"
#显示我家庭成员的数量
> scard family
2
#判断我是否是家庭的成员之一
> sismember family zhibin
(integer) 1
如下表显示与排序集的一些基本命令:
S.N. | 命令& 描述 |
---|
1 | SADD key member1 [member2...] 添加一个或多个成员到集合,添加成功返回1,成员已经存在或失败则返回0 |
2 | SMEMBERS key 得到的集合的所有成员 |
3 | SINTER key [key ...] 返回一个给定集合的交集 |
4 | SMOVE source destination member 将member元素从source集合移动到destination集合。 |
5 | SUNION key [key ...] 返回一个集合的全部成员,该集合是所有给定集合的并集。 |
6 | SCARD key 返回集合的基数 |
7 | SINTERSTORE destination key [key ...] 此命令等同于SINTER,但它将结果保存到destination集合,而不是简单地返回结果集。 |
8 | SPOP key 移除并返回集合中的一个随机元素。 |
9 | SUNIONSTORE destination key [key ...] 此命令等同于SUNION,但它将结果保存到destination集合,而不是简单地返回结果集。 |
10 | SDIFF key [key ...] 返回第一个给定集合和其他所有给定集合的差集 。 |
11 | SISMEMBER key member 判断member元素是否是集合的成员。 |
12 | SRANDMEMBER key 返回集合中的一个随机元素。 |
13 | SDIFFSTORE destination key [key ...] 此命令等同于SDIFF,但它将结果保存到destination集合,而不是简单地返回结果集。 |
14 | SREM key member 移除集合中的member元素。 |
| |