设为首页 收藏本站
查看: 722|回复: 0

[经验分享] Redis 集合处理

[复制链接]

尚未签到

发表于 2017-12-21 12:09:16 | 显示全部楼层 |阅读模式
  学习了列表之后,发现了Redis处理字符串的功能强大。
  为了适应不同场景的需求,还有一个用的很多的就是集合。
  Redis提供的集合支持的类型是字符串。并且集合中的元素值是唯一的,也就是说不能出现重复数据。
  而且,集合的实现是通过哈希的方式,在修改集合的时候复杂度都为O(1)。
  Redis支持集合的最大数量为2^32 - 1个。

1、SADD 命令
  用于将一个或多个元素加入到指定的集合中,由于集合不存在重复元素,所以已经存在的成员会被忽略。
  如果指定的集合不存在,则该命令会创建该集合,并且把元素加入进去。
  如果指定的KEY不是一个集合,则返回一个错误说明。
  

127.0.0.1:6379> SADD KEY MEMBER [member ...]  

  例如,
  

127.0.0.1:6379> SET SET A  
OK
  

127.0.0.1:6379> SADD SET 1 2 3 4 5  
(error) WRONGTYPE Operation against a key holding the wrong kind of value
  

127.0.0.1:6379> SADD SET1 1 2 3 4 5  
(integer)
5  
127.0.0.1:6379> SMEMBERS SET1
  
1) "1"
  
2) "2"
  
3) "3"
  
4) "4"
  
5) "5"
  


2、SCARD 命令
  用于返回指定集合中元素的数量。
  

127.0.0.1:6379> SCARD KEY   

  例如,
  

127.0.0.1:6379> SCARD SET1  
(integer)
5  


3、SDIFF 命令
  用于返回给定集合之间的差集。
  一定是前面的集合减去后面的集合,剩余的元素。
  

127.0.0.1:6379> SDIFF KEY KEY [key ...]  

  例如,
  

127.0.0.1:6379> sadd SET 1 2 3 4 5  
(integer)
5  
127.0.0.1:6379> sadd SET1 1 2 3
  
(integer) 3
  
127.0.0.1:6379> sdiff SET1 SET
  
(empty list or set)
  
127.0.0.1:6379> sdiff SET SET
  
(empty list or set)
  
127.0.0.1:6379> sdiff SET SET1
  
1) "4"
  
2) "5"
  
127.0.0.1:6379> sadd SET2 1 2 3 4 5 6
  
(integer) 6
  
127.0.0.1:6379> sdiff SET SET1 SET2
  
(empty list or set)
  
127.0.0.1:6379> sdiff SET2 SET1 SET
  
1) "6"
  


4、SDIFFSTORE 命令
  用于将给定集合之间的差集存储在指定的集合中。
  如果指定的DESTINATION集合已存在,则里面的元素会被覆盖。
  

127.0.0.1:6379> SDIFFSTORE DESTINATION KEY KEY [key ...]  

  例如,
  

127.0.0.1:6379> SDIFFSTORE SET2 SET SET1  
(integer)
2  
127.0.0.1:6379> SMEMBERS SET2
  
1) "4"
  
2) "5"
  
127.0.0.1:6379> SMEMBERS SET1
  
1) "1"
  
2) "2"
  
3) "3"
  
127.0.0.1:6379> SMEMBERS SET
  
1) "1"
  
2) "2"
  
3) "3"
  
4) "4"
  
5) "5"
  


5、SINTER 命令
  用于返回给定所有集合的交集。
  不存在的集合被视为空集,当给定的集合当中有一个时空集时,结果也为空集。
  

127.0.0.1:6379> SINTER KEY KEY [key ...]  

  例如,
  

127.0.0.1:6379> SMEMBERS SET1  

1) "1"  
2) "2"
  
3) "3"
  
127.0.0.1:6379> SMEMBERS SET
  
1) "1"
  
2) "2"
  
3) "3"
  
4) "4"
  
5) "5"
  
127.0.0.1:6379> SINTER SET SET1
  
1) "1"
  
2) "2"
  
3) "3"
  


6、SINTERSTORE 命令
  用于将给定集合之间的交集存储在指定的集合中。
  如果指定的DESTINATION集合已存在,则里面的元素会被覆盖。
  

127.0.0.1:6379> SINTERSTORE DESTINATION KEY KEY [key ...]  

  例如,
  

127.0.0.1:6379> SINTERSTORE SET2 SET SET1  
(integer)
3  
127.0.0.1:6379> SMEMBERS SET2
  
1) "1"
  
2) "2"
  
3) "3"
  
127.0.0.1:6379> SMEMBERS SET
  
1) "1"
  
2) "2"
  
3) "3"
  
4) "4"
  
5) "5"
  
127.0.0.1:6379> SMEMBERS SET1
  
1) "1"
  
2) "2"
  
3) "3"
  


7、SISMEMBER 命令
  用于判断给定的元素是否为指定集合的成员。
  如果给定的元素是集合成员,则返回1,如果不是,则返回0。
  

127.0.0.1:6379> SISMEMBER KEY MEMBER   

  例如,
  

127.0.0.1:6379> SMEMBERS SET  

1) "1"  
2) "2"
  
3) "3"
  
4) "4"
  
5) "5"
  
127.0.0.1:6379> sismember SET 0
  
(integer) 0
  
127.0.0.1:6379> sismember SET 1
  
(integer) 1
  


8、SMEMBERS 命令
  用于返回指定集合中所有的成员。不存在的集合被视为空集。
  

127.0.0.1:6379> SMEMBERS KEY  

  例如,
  

127.0.0.1:6379> SMEMBERS SET  

1) "1"  
2) "2"
  
3) "3"
  
4) "4"
  
5) "5"
  
127.0.0.1:6379> SMEMBERS SE
  
(empty list or set)
  


9、SMOVE 命令
  用于将指定成员元素从SOURCE集合移动到DESTINATION集合中。
  并且,SMOVE是原子性操作。
  如果SOURCE集合不存在或者不包含指定的元素,则不执行任何操作,返回0。
  如果DESTINATION集合中已经包含了指定元素,SMOVE操作将该元素从SOURCE集合中删除。
  如果SOURCE与DESTINATION不是集合类型是,则返回一个错误说明。
  

127.0.0.1:6379> SMOVE SOURCE DESTINATION MEMBER   

  例如,
  

127.0.0.1:6379> SMEMBERS SET  

1) "1"  
2) "2"
  
3) "3"
  
4) "4"
  
5) "5"
  
127.0.0.1:6379> SMEMBERS SET1
  
1) "1"
  
2) "2"
  
3) "3"
  
127.0.0.1:6379> SMOVE SET SET1 4
  
(integer) 1
  
127.0.0.1:6379> SMOVE SET SET1 5
  
(integer) 1
  
127.0.0.1:6379> SMOVE SET SET1 6
  
(integer) 0
  


10、SPOP 命令
  用于随机获取指定集合中的一个或几个元素,并且该元素从集合中删除。
  获取的个数由COUNT指定,当指定的个数超过集合的元素个数时,仅返回剩余元素。
  当集合为空时,返回空集。COUNT只能为正数,如果是负数,则返回一个错误说明。
  

127.0.0.1:6379> SPOP KEY [count]  

  例如,
  

127.0.0.1:6379> SPOP SET 1  
1) "1"
  
127.0.0.1:6379> SPOP SET 3
  
1) "2"
  
2) "3"
  
127.0.0.1:6379> SPOP SET 3
  
(empty list or set)
  127.0.0.1:6379> SPOP SET -1
  (error) ERR index out of range
  


11、SRANDMEMBER 命令
  用于随机获取指定集合中的一个或几个元素但不删除,并且获取的个数由COUNT指定。
  如果COUNT是正数,且小于集合基数,则返回COUNT个元素的数组,其中元素内容不重复。
  如果COUNT是正数,且大于集合基数,则返回整个集合。
  如果COUNT是负数,则返回COUNT个元素的数组,数组中的元素可以重复。
  当集合为空时,返回空集。
  

127.0.0.1:6379> SRANDMEMBER SET [count]  

  例如,
  

127.0.0.1:6379> SRANDMEMBER SET 4  
1) "9"
  
2) "8"
  
3) "5"
  
4) "6"
  
127.0.0.1:6379> SRANDMEMBER SET 4
  
1) "9"
  
2) "2"
  
3) "8"
  
4) "6"
  
127.0.0.1:6379> SRANDMEMBER SET -2
  
1) "8"
  
2) "2"
  
127.0.0.1:6379> SRANDMEMBER SET -2
  
1) "2"
  
2) "5"
  
127.0.0.1:6379> SRANDMEMBER SET -8
  
1) "10"
  
2) "3"
  
3) "3"
  
4) "10"
  
5) "1"
  
6) "6"
  
7) "8"
  
8) "10"
  


12、SREM 命令
  用于删除给定集合中的一个或几个元素,不存在的元素将被忽略。
  当KEY不是一个集合时,则返回一个错误说明。
  

127.0.0.1:6379> SREM KEY MEMBER [member ...]  

  例如,
  

127.0.0.1:6379> SMEMBERS SET  

1) "1"  
2) "2"
  
3) "3"
  
4) "4"
  
5) "5"
  
6) "6"
  
7) "7"
  
8) "8"
  
9) "9"
  
10) "10"
  
127.0.0.1:6379> SREM SET 1 3 5 7 9 11
  
(integer) 5
  
127.0.0.1:6379> SMEMBERS SET
  
1) "2"
  
2) "4"
  
3) "6"
  
4) "8"
  
5) "10"
  


13、SUNION 命令
  用于返回给定集合的并集。不存在的集合被视为空集。
  

127.0.0.1:6379> SUNION KEY KEY [key ...]  

  例如,
  

127.0.0.1:6379> SUNION SET SET1 SET2  

1) "1"  
2) "2"
  
3) "3"
  
4) "4"
  
5) "5"
  
6) "6"
  
7) "8"
  
8) "10"
  
127.0.0.1:6379> SMEMBERS SET
  
1) "2"
  
2) "4"
  
3) "6"
  
4) "8"
  
5) "10"
  
127.0.0.1:6379> SMEMBERS SET1
  
1) "1"
  
2) "2"
  
3) "3"
  
4) "4"
  
5) "5"
  
127.0.0.1:6379> SMEMBERS SET2
  
1) "1"
  
2) "2"
  
3) "3"
  


14、SUNIONSTORE 命令
  用于将给定的集合的并集存储在指定的集合DESTINATION中。
  如果指定的DESTINATION集合已存在,则里面的元素会被覆盖。
  

127.0.0.1:6379> SUNIONSTORE DESTINATION KEY KEY [key ...]  

  例如,
  

127.0.0.1:6379> SMEMBERS SET2  

1) "1"  
2) "2"
  
3) "3"
  
127.0.0.1:6379> SUNIONSTORE SET2 SET SET1
  
(integer) 8
  
127.0.0.1:6379> SMEMBERS SET2
  
1) "1"
  
2) "2"
  
3) "3"
  
4) "4"
  
5) "5"
  
6) "6"
  
7) "8"
  
8) "10"
  
127.0.0.1:6379>
  


15、SSCAN 命令
  SCAN命令及其相关的SSCAN命令、HSCAN命令和ZSCAN命令都用于增量地迭代一集元素。
  SSCAN命令用于迭代集合键中的元素。
  与SCAN命令类型。
  

127.0.0.1:6379> sscan SET cursor [MATCH pattern] [COUNT count]  

  例如,
  

127.0.0.1:6379> SSCAN SET 0 MATCH *  
1) "0"
  
2) 1) "2"
  
2) "4"
  
3) "6"
  
4) "8"
  
5) "10"
  
127.0.0.1:6379> SSCAN SET 0
  
1) "0"
  
2) 1) "2"
  
2) "4"
  
3) "6"
  
4) "8"
  
5) "10"
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-426413-1-1.html 上篇帖子: Redis设计与实现:读书笔记之二 下篇帖子: Redis 数据变化通知服务实践
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表