redis中set集合操作(四)

和java中的set集合很相似,不允许重复,没有任何顺序,不是按插入顺序来排,大概像散列排吧

命令示例

1. SADD/SMEMBERS/SCARD/SISMEMBER:(增加/列出所有成员/获取成员数量/判断是否是成员)

127.0.0.1:6379> sadd myset a b c    //添加set的别名为myset,里面的值为a,b,c
(integer) 3
127.0.0.1:6379> sadd myset a d e //再往里面添加,但是因为已经有a了,所以a添加失败,其他的添加成功
(integer) 2
127.0.0.1:6379> sismember myset a  //判断myset里是否有a,有返回1,没有返回0
(integer) 1 
127.0.0.1:6379> sismember myset f   
(integer) 0
127.0.0.1:6379> smembers myset  //获得myset里所有的值
1) "a"
2) "c"
3) "d"
4) "e"
5) "b"
127.0.0.1:6379> scard myset  //获得myset的长度也是值的数量
(integer) 5

2. SPOP/SREM/SRANDMEMBER/SMOVE:(随机弹出一个/根据键值删除/随机获取一个且不会删除/从一个set移到另一个set)

127.0.0.1:6379> del myset
(integer) 1
127.0.0.1:6379> sadd myset a b c d 
(integer) 4
127.0.0.1:6379> smembers myset   
1) "b"
2) "a"
3) "d"
4) "c"
127.0.0.1:6379> srandmember myset  //随机获得一个值
"a"
127.0.0.1:6379>  srandmember myset //随机获得一个值
"d"
127.0.0.1:6379> spop myset //弹出尾部的值
"c"
127.0.0.1:6379> smembers myset  //查看弹出尾部值还剩的值
1) "b"
2) "a"
3) "d"
127.0.0.1:6379> srem myset a d f //从Set中移出a、d和f三个成员,其中f并不存在,因此只有a和d两个成员被移出,返回为2
(integer) 2
127.0.0.1:6379> smembers myset  // 查看移出后的输出结果
1) "b"
127.0.0.1:6379> sadd myset a b //为后面的smove命令准备数据
(integer) 1
127.0.0.1:6379> sadd myset d e f
(integer) 3
127.0.0.1:6379> sadd myset2 c d
(integer) 2
127.0.0.1:6379> smove myset myset2 a //将a从myset移到myset2,从结果可以看出移动成功
(integer) 1
127.0.0.1:6379> smove myset myset2 a / /再次将a从myset移到myset2,由于此时a已经不是myset的成员了,因此移动失败并返回0
(integer) 0
127.0.0.1:6379> smembers myset //分别查看myset和myset2的成员,确认移动是否真的成功
1) "d"
2) "e"
3) "b"
4) "f"
127.0.0.1:6379> smembers myset2
1) "a"
2) "d"
3) "c"

3. SDIFF/SDIFFSTORE/SINTER/SINTERSTORE/SUNION/SUNIONSTORE:(判断不同/求出不同且存到另一个set/求交集/将交集存到另一个set/求并集/求并集并存到另一个set)

127.0.0.1:6379> del myset  //清空数据
(integer) 1
127.0.0.1:6379> del myset2
(integer) 1
127.0.0.1:6379> del myset3
(integer) 1
127.0.0.1:6379> sadd myset a b c d  //准备数据
(integer) 4
127.0.0.1:6379> sadd myset2 c
(integer) 1
127.0.0.1:6379> sadd myset3 a c e
(integer) 3
//myset和myset2相比,a、b和d三个成员是两者之间的差异成员。再用这个结果继续和myset3进行差异比较,b和d是myset3不存在的成员。
127.0.0.1:6379> sdiff myset myset2 myset3
1) "b"
2) "d"
将3个集合的差异成员存在在diffkey关联的Set中,并返回插入的成员数量
127.0.0.1:6379> sdiffstore diffkey myset myset2 myset3
(integer) 2
127.0.0.1:6379> smembers diffkey  //查看一下sdiffstore的操作结果
1) "b"
2) "d"
127.0.0.1:6379> sinter myset myset2 myset3 //从之前准备的数据就可以看出,这三个Set的成员交集只有c
1) "c"
127.0.0.1:6379> sinterstore interkey myset myset2 myset3 //将3个集合中的交集成员存储到与interkey关联的Set中,并返回交集成员的数量
(integer) 1
127.0.0.1:6379> smembers interkey //查看一下sinterstore的操作结果
1) "c"
127.0.0.1:6379> sunion myset myset2 myset3 //获取3个集合中的成员的并集
1) "a"
2) "d"
3) "c"
4) "e"
5) "b"
127.0.0.1:6379> sunionstore unionkey myset myset2 myset3  //将3个集合中成员的并集存储到unionkey关联的set中,并返回并集成员的数量
(integer) 5
127.0.0.1:6379> smembers unionkey //查看一下suiionstore的操作结果
1) "a"
2) "d"
3) "c"
4) "e"
5) "b"

四、应用范围:(摘抄https://www.cnblogs.com/qlqwjy/p/7797356.html)

1). 可以使用Redis的Set数据类型跟踪一些唯一性数据,比如访问某一博客的唯一IP地址信息。对于此场景,我们仅需在每次访问该博客时将访问者的IP存入Redis中,Set数据类型会自动保证IP地址的唯一性。
2). 充分利用Set类型的服务端聚合操作方便、高效的特性,可以用于维护数据对象之间的关联关系。比如所有购买某一电子设备的客户ID被存储在一个指定的Set中,而购买另外一种电子产品的客户ID被存储在另外一个Set中,如果此时我们想获取有哪些客户同时购买了这两种商品时,Set的intersections命令就可以充分发挥它的方便和效率的优势了。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值