Redis学习06——存储字符串集合(set)

Redis学习06——存储字符串集合(set)

一、字符串集合(set)说明

在Redis中,我们可以将set类型看作为没有排序的字符串集合,和List类型一样,我们也可以在该类型上执行添加、删除或者判断某个元素是否存在等操作。需要说明的是,这些操作的时间复杂度为O(1),即常量时间内完成操作。Set可以包含的最大元素数量是4294967295。和List类型不同的是,Set集合中不允许出现重复的数据。和List相比,Set类型在功能上还存在着一个非常重要的特性,即在服务器端完成多个Set之间的聚合计算操作,如unions、intersections、differences。由于这些操作均在服务端完成,因此效率极高,而且也节省了大量的网络IO开销。

这里写图片描述


二、添加元素

命令:

sadd key value1 value2 .....

含义:
向 set 中添加数据,如果该value已经存在,那么不会重复添加

示例

127.0.0.1:6379> sadd myset1 a b c d e f
(integer) 6
127.0.0.1:6379> sadd myset1 a 
(integer) 0

三、删除元素

命令:

srem key member1 member2 .....

含义:
删除set中指定的成员

示例

127.0.0.1:6379> srem myset1 a b c
(integer) 3

四、获得集合中的元素

命令:

smembers key

含义:
获取set集合中所有的成员

示例

127.0.0.1:6379> smembers myset1
1) "e"
2) "f"
3) "d"

五、判断成员是否存在

命令:

sismember key member

含义:
判断参数中指定的成员是否存在该set中,1表示存在,0表示不存在或者该key本身不存在

示例

127.0.0.1:6379> sismember myset1 e
(integer) 1
127.0.0.1:6379> sismember myset1 x
(integer) 0
127.0.0.1:6379> sismember myset1111 a
(integer) 0

六、集合的差集运算 A-B | B-A

命令:

sdiff key1 key2 ....

含义:
返回key1 与key2 中相差的成员,而且与key的顺序有关,即返回差集。

这里写图片描述

这里写图片描述

示例

127.0.0.1:6379> sadd myset1 a b c
(integer) 3
127.0.0.1:6379> sadd myset2 a c e g h i
(integer) 6
127.0.0.1:6379> smembers myset1
1) "b"
2) "e"
3) "a"
4) "f"
5) "d"
6) "c"
127.0.0.1:6379> smembers myset2
1) "c"
2) "g"
3) "e"
4) "i"
5) "a"
6) "h"
127.0.0.1:6379> sdiff myset1 myset2
1) "d"
2) "f"
3) "b"
127.0.0.1:6379> sdiff myset2 myset1
1) "i"
2) "h"
3) "g"

七、集合的交集运算

命令:

sinter key1 key2 ....

含义:
返回交集

这里写图片描述

示例

127.0.0.1:6379> smembers myset1
1) "b"
2) "e"
3) "a"
4) "f"
5) "d"
6) "c"
127.0.0.1:6379> smembers myset2
1) "e"
2) "g"
3) "i"
4) "a"
5) "c"
6) "h"
127.0.0.1:6379> sinter myset1 myset2
1) "e"
2) "a"
3) "c"

八、集合的并集运算

命令:

sunion key1 key2 ....

含义:
返回并集

这里写图片描述

示例

127.0.0.1:6379> smembers myset1
1) "b"
2) "e"
3) "a"
4) "f"
5) "d"
6) "c"
127.0.0.1:6379> smembers myset2
1) "e"
2) "g"
3) "i"
4) "a"
5) "c"
6) "h"
127.0.0.1:6379> sunion myset1 myset2
1) "i"
2) "a"
3) "f"
4) "d"
5) "c"
6) "b"
7) "h"
8) "e"
9) "g"

九、其他命令

9.1 scard key

命令:

scard key

含义:
获取set中成员的数量

示例

127.0.0.1:6379> smembers myset1
1) "b"
2) "e"
3) "a"
4) "f"
5) "d"
6) "c"
127.0.0.1:6379> scard myset1
(integer) 6

9.2 srandmember key

命令:

srandmember key

含义:
随机返回set中的一个成员

示例

127.0.0.1:6379> smembers myset1
1) "b"
2) "e"
3) "a"
4) "f"
5) "d"
6) "c"
127.0.0.1:6379> srandmember myset1
"b"
127.0.0.1:6379> srandmember myset1
"e"

9.3 sinterstore destination key1 key2 …..

命令:

sinterstore destination key1 key2 .....

含义:
将返回的交集存储到destination上

示例

127.0.0.1:6379> smembers myset3
(empty list or set)
127.0.0.1:6379> sinter myset1 myset2
1) "e"
2) "a"
3) "c"
127.0.0.1:6379> sinterstore myset3 myset1 myset2
(integer) 3
127.0.0.1:6379> smembers myset3
1) "a"
2) "c"
3) "e"

9.4 sunionstore destination key1 key2 ….

命令:

sunionstore destination key1 key2 .....

含义:
将返回的并集存储到destination上

示例

127.0.0.1:6379> smembers myset4
(empty list or set)
127.0.0.1:6379> sunion myset1 myset2
1) "i"
2) "a"
3) "f"
4) "d"
5) "c"
6) "b"
7) "h"
8) "e"
9) "g"
127.0.0.1:6379> sunionstore myset4 myset1 myset2
(integer) 9
127.0.0.1:6379> smembers myset4
1) "i"
2) "a"
3) "f"
4) "d"
5) "c"
6) "b"
7) "h"
8) "e"
9) "g"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值