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元素。
|
|
|