redis 系列文章:
https://liudongdong.top/categ…
本篇起源:
https://liudongdong.top/archi…公众号:雨中散步撒哈拉
备注:欢送关注公众号,一起学习,共同进步!
一、基本概念
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>
二、Set 分类
依据集体了解和便于学习,进行了简略的分类!
大抵分为以下几类:
- 减少成员
- 删除成员
- 批改成员
- 查问成员
- 汇合操作
1. 减少成员
- sadd:减少成员
2. 删除成员
- spop:移除随机成员
- srem:移除指定成员
3. 批改成员命令
- smove:挪动成员到另一个汇合中
4. 查问成员
- scard:查问成员总数
- sismember:查问该成员是否存在
- smembers:查问所有成员
- srandmember:返回汇合一个或多个随机数
5. 汇合操作
- sdiff:俩个汇合之间的差集
- sdiffstore:俩个汇合之间的差集,后果放到新的 set 中
- sinter:俩个汇合之间的交加
- sinterstore:俩个汇合之间的交加,后果放到新的 set 中
- sunion:俩个汇合之间的并集
- sunionstore:俩个汇合之间的并集,后果放到新的 set 中
三、命令实际
1. 减少成员
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>
2. 删除成员
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>
3. 批改成员
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>
4. 查问成员
# 查问成员总数
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>
5. 汇合操作
1. 差集
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>
2. 交加
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>
3. 并集
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] 迭代汇合中的元素 |