您的位置:首页 > 数据库 > Redis

redis之集合类型(set)

2015-12-24 22:20 555 查看
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.命令& 描述
1SADD
key member1 [member2...]

添加一个或多个成员到集合,添加成功返回1,成员已经存在或失败则返回0
2SMEMBERS
key

得到的集合的所有成员
3SINTER
key [key ...]

返回一个给定集合的交集
4SMOVE
source destination member
将member元素从source集合移动到destination集合。
5SUNION
key [key ...]
返回一个集合的全部成员,该集合是所有给定集合的并集。
6SCARD
key

返回集合的基数
7SINTERSTORE
destination key [key ...]
此命令等同于SINTER,但它将结果保存到destination集合,而不是简单地返回结果集。
8SPOP
key
移除并返回集合中的一个随机元素。
9SUNIONSTORE
destination key [key ...]
此命令等同于SUNION,但它将结果保存到destination集合,而不是简单地返回结果集。
10SDIFF
key [key ...]
返回第一个给定集合和其他所有给定集合的差集 。
11SISMEMBER
key member
判断member元素是否是集合的成员。
12SRANDMEMBER
key
返回集合中的一个随机元素。
13SDIFFSTORE
destination key [key ...]
此命令等同于SDIFF,但它将结果保存到destination集合,而不是简单地返回结果集。
14SREM
key member
移除集合中的member元素。
  
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: