redis系列文章:
https://liudongdong.top/categories/redis
本篇来源:
https://liudongdong.top/archives/redisliu-redis-zhi-set公众号:雨中散步撒哈拉
备注:欢迎关注公众号,一起学习,共同进步!
Redis 的 Set 是 String 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
集合对象的编码可以是 intset 或者 hashtable。
Redis 中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。
集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
实例:
127.0.0.1:6379> sadd sets one two three (integer) 3 127.0.0.1:6379> smembers sets 1) "three" 2) "one" 3) "two" 127.0.0.1:6379>
根据个人理解和便于学习,进行了简单的分类!
大致分为以下几类:
增加成员
删除成员
修改成员
查询成员
集合操作
spop:移除随机成员
srem:移除指定成员
scard:查询成员总数
sismember:查询该成员是否存在
smembers:查询所有成员
srandmember:返回集合一个或多个随机数
sdiff:俩个集合之间的差集
sdiffstore:俩个集合之间的差集,结果放到新的set中
sinter:俩个集合之间的交集
sinterstore:俩个集合之间的交集,结果放到新的set中
sunion:俩个集合之间的并集
sunionstore:俩个集合之间的并集,结果放到新的set中
127.0.0.1:6379> sadd sets one two three (integer) 3 127.0.0.1:6379> smembers sets 1) "three" 2) "one" 3) "two" 127.0.0.1:6379>
127.0.0.1:6379> smembers sets 1) "three" 2) "one" 3) "two" # 删除一个或多个随机值 127.0.0.1:6379> spop sets 1 1) "three" 127.0.0.1:6379> smembers sets 1) "one" 2) "two" # 移除指定成员 127.0.0.1:6379> srem sets one (integer) 1 127.0.0.1:6379> smembers sets 1) "two" 127.0.0.1:6379>
127.0.0.1:6379> smembers sets 1) "two" 127.0.0.1:6379> sadd sets2 a (integer) 1 127.0.0.1:6379> smembers sets2 1) "a" # 修改成员,到新的集合中 127.0.0.1:6379> smove sets sets2 two (integer) 1 127.0.0.1:6379> smembers sets2 1) "a" 2) "two" 127.0.0.1:6379> smembers sets (empty list or set) 127.0.0.1:6379>
# 查询成员总数 127.0.0.1:6379> scard sets2 (integer) 2 # 查询集合所有成员 127.0.0.1:6379> smembers sets2 1) "a" 2) "two" # 判断成员是否存在集合中 127.0.0.1:6379> sismember sets2 one (integer) 0 127.0.0.1:6379> sismember sets2 two (integer) 1 # 返回集合中的一个或多个值 127.0.0.1:6379> srandmember sets2 1 1) "two" 127.0.0.1:6379> srandmember sets2 1 1) "two" 127.0.0.1:6379> srandmember sets2 2 1) "a" 2) "two" 127.0.0.1:6379>
Redis Sdiff 命令返回第一个集合与其他集合之间的差异,也可以认为说第一个集合中独有的元素。不存在的集合 key 将视为空集。
差集的结果来自前面的 FIRST_KEY ,而不是后面的 OTHER_KEY1,也不是整个 FIRST_KEY OTHER_KEY1…OTHER_KEYN 的差集。
127.0.0.1:6379> smembers sets 1) "c" 2) "a" 3) "b" 127.0.0.1:6379> smembers sets2 1) "a" 2) "two" 127.0.0.1:6379> sdiff sets sets2 1) "c" 2) "b" 127.0.0.1:6379> sadd sets3 1 (integer) 1 127.0.0.1:6379> sdiffstore sets3 sets sets2 (integer) 2 127.0.0.1:6379> smembers sets3 1) "c" 2) "b" 127.0.0.1:6379>
Redis Sinter 命令返回给定所有给定集合的交集。不存在的集合 key 被视为空集。当给定集合当中有一个空集时,结果也为空集(根据集合运算定律)。
127.0.0.1:6379> smembers sets 1) "c" 2) "a" 3) "b" 127.0.0.1:6379> smembers sets2 1) "a" 2) "two" 127.0.0.1:6379> smembers sets3 1) "c" 2) "b" 127.0.0.1:6379> sinter sets sets2 1) "a" 127.0.0.1:6379> sinterstore sets3 sets sets2 (integer) 1 127.0.0.1:6379> smembers sets3 1) "a" 127.0.0.1:6379>
Redis Sunion 命令返回给定集合的并集。不存在的集合 key 被视为空集。
127.0.0.1:6379> smembers sets 1) "c" 2) "a" 3) "b" 127.0.0.1:6379> smembers sets2 1) "a" 2) "two" 127.0.0.1:6379> smembers sets3 1) "a" 127.0.0.1:6379> sunion sets sets2 1) "a" 2) "c" 3) "two" 4) "b" 127.0.0.1:6379> sunionstore sets3 sets sets2 (integer) 4 127.0.0.1:6379> smembers sets3 1) "a" 2) "c" 3) "two" 4) "b" 127.0.0.1:6379>
下表列出了 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] 迭代集合中的元素 |