1.SADD
SADD key member [member ...]
将一个或多个 member 元素加入到集合 key 当中,已经存在于集合的 member 元素将被忽略。
假如 key 不存在,则创建一个只包含 member 元素作成员的集合。
当 key 不是集合类型时,返回一个错误。
在Redis2.4版本以前, SADD 只接受单个 member 值。
可用版本:>= 1.0.0
时间复杂度:O(N), N 是被添加的元素的数量。
返回值:被添加到集合中的新元素的数量,不包括被忽略的元素。
127.0.0.1:6379> flushdb OK 127.0.0.1:6379> sadd names tom jerry // 添加2个元素 (integer) 2 127.0.0.1:6379> sadd names tom // 添加重复元素 (integer) 0 127.0.0.1:6379> sadd names zhangsan lisi (integer) 2 127.0.0.1:6379> smembers names 1) "lisi" 2) "jerry" 3) "zhangsan" 4) "tom"
2.SCARD
SCARD key
返回集合 key 的基数(集合中元素的数量)。
可用版本:>= 1.0.0
时间复杂度:O(1)
返回值:
集合的基数。
当 key 不存在时,返回 0 。
127.0.0.1:6379> sadd names tom jerry zhangsan lisi (integer) 4 127.0.0.1:6379> scard names (integer) 4 127.0.0.1:6379> exists ages // key不存在 (integer) 0 127.0.0.1:6379> scard ages (integer) 0
3.SDIFF
SDIFF key [key ...]
返回一个集合的全部成员,该集合是所有给定集合之间的差集。
不存在的 key 被视为空集。
可用版本:>= 1.0.0
时间复杂度:O(N), N 是所有给定集合的成员数量之和。
返回值: 差集成员的列表。
127.0.0.1:6379> sadd name1 tom jerry zhangsan (integer) 3 127.0.0.1:6379> sadd name2 jack jerry lisi (integer) 3 127.0.0.1:6379> sdiff name1 name2 1) "tom" 2) "zhangsan" 127.0.0.1:6379> sdiff name2 name1 1) "lisi" 2) "jack"
4.SDIFFSTORE
SDIFFSTORE destination key [key ...]
这个命令的作用和 SDIFF 类似,但它将结果保存到 destination 集合,而不是简单地返回结果集。
如果 destination 集合已经存在,则将其覆盖。
destination 可以是 key 本身。
可用版本:>= 1.0.0
时间复杂度:O(N), N 是所有给定集合的成员数量之和。
返回值:结果集中的元素数量。
redis> SMEMBERS joe's_movies 1) "hi, lady" 2) "Fast Five" 3) "2012" redis> SMEMBERS peter's_movies 1) "bet man" 2) "start war" 3) "2012" redis> SDIFFSTORE joe_diff_peter joe's_movies peter's_movies (integer) 2 redis> SMEMBERS joe_diff_peter 1) "hi, lady" 2) "Fast Five"
5.SINTER
SINTER key [key ...]
返回一个集合的全部成员,该集合是所有给定集合的交集。
不存在的 key 被视为空集。
当给定集合当中有一个空集时,结果也为空集(根据集合运算定律)。
可用版本:>= 1.0.0
时间复杂度:O(N * M), N 为给定集合当中基数最小的集合, M 为给定集合的个数。
返回值:交集成员的列表。
redis> SMEMBERS group_1 1) "LI LEI" 2) "TOM" 3) "JACK" redis> SMEMBERS group_2 1) "HAN MEIMEI" 2) "JACK" redis> SINTER group_1 group_2 1) "JACK"