微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

NoSQL之Redis对set(集合)数据类型的操作之二

7.sinter setkey1 setkey2 setkey3...:返回setkey1和setkey2的交集

127.0.0.1:6379> smembers setkey1
1) "world"
2) "hello"
3) "2000"
127.0.0.1:6379> smembers setkey2
1) "3000"
2) "world"
3) "2000"
127.0.0.1:6379> smembers setkey3
1) "3000"
127.0.0.1:6379> sinter setkey1 setkey2
1) "world"
2) "2000"
127.0.0.1:6379> sinter setkey1 setkey2 setkey3
(empty list or set)
127.0.0.1:6379> sadd setkey3 2000
(integer) 1
127.0.0.1:6379> sinter setkey1 setkey2 setkey3
1) "2000"

8.sinterstore setkey3 setkey1 setkey2..:将取到的交集存储到setkey3中。同sdiffstore

127.0.0.1:6379> sinterstore setkey5 setkey1 setkey2
(integer) 2
127.0.0.1:6379> smembers setkey5
1) "world"
2) "2000"

9.sunion setkey1 setkey2 setkey3....:取给定所有key的并集

127.0.0.1:6379> smembers setkey1
1) "world"
2) "hello"
3) "2000"
127.0.0.1:6379> smembers setkey2
1) "3000"
2) "world"
3) "2000"
127.0.0.1:6379> sunion setkey1 setkey2
1) "hello"
2) "2000"
3) "world"
4) "3000"

10.sunionstore setkey3 setkey1 setkey2...:将并集存到setkey3中

127.0.0.1:6379> sunionstore setkey6 setkey1 setkey2
(integer) 4
127.0.0.1:6379> smembers setkey6
1) "hello"
2) "2000"
3) "world"
4) "3000"

11.smove setkey1 setkey2 value:从setkey1中移除一个元素value到setkey2中。

127.0.0.1:6379> smembers setkey1
1) "world"
2) "hello"
3) "2000"
127.0.0.1:6379> smembers setkey2
1) "3000"
2) "world"
3) "2000"
127.0.0.1:6379> smove setkey1 setkey2 hello
(integer) 1
127.0.0.1:6379> smembers setkey2
1) "3000"
2) "world"
3) "hello"
4) "2000"
127.0.0.1:6379> smembers setkey1
1) "world"
2) "2000"
127.0.0.1:6379> smove setkey1 setkey2 world
(integer) 1
127.0.0.1:6379> smembers setkey1
1) "2000"
127.0.0.1:6379> smembers setkey2
1) "3000"
2) "world"
3) "hello"
4) "2000"

大家仔细看一下上面的例子。就会发现,如果被移动的value在setkey2中已经存在,那么就相当于srem setkey1 value,仅仅是将value元素从setkey1中删除

12.scard setkey:查看setkey集合中元素的个数

127.0.0.1:6379> smembers setkey1
1) "3000"
2) "2000"
127.0.0.1:6379> scard setkey1
(integer) 2

如果集合中没有元素那么返回integer 0

13.sismember setkey value:测试value是否是名称为setkey的集合的元素。返回1代表是,返回0代表不是。

127.0.0.1:6379> smembers setkey1
1) "3000"
2) "2000"
127.0.0.1:6379> sismember setkey1 2000
(integer) 1
127.0.0.1:6379> sismember setkey1 4000
(integer) 0

14.srandmember setkey:随机返回setkey的一个元素,但是不删除元素。

127.0.0.1:6379> smembers setkey1
1) "1000"
2) "4000"
3) "3000"
4) "5000"
5) "2000"
127.0.0.1:6379> srandmember setkey1
"5000"
127.0.0.1:6379> srandmember setkey1
"2000"
127.0.0.1:6379> srandmember setkey1
"1000"

最后强调一点,set里的数据是无序的。

通过学习并且测试上面的方法,一些细心的同学很容易能察觉到,用set来操作目前流行的sns或者微博的一些动态信息,实时消息或者实时推荐和分析都会非常方便。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


校园网上订餐系统系统主要功能模块包括公告内容(公告栏、轮播图)用户管理(管理员、普通用户)、内容模块(资讯分类、资讯列表)、模块管理(菜品分类、菜单、订单表),采取面对对象的开发模式进行软件的开发和硬体的架设,能很好的满足实际使用的需求,完善了对应的软体架设以及程序编码的工作,采取MySQL作为后台数据的主要存储单元,采用SSM框架、Java技术、Ajax技术进行业务系统的编码及其开发,实现了本系统的全部功能。本次报告,首先分析了研究的背景、作用、意义,为研究工作的合理性打下了基础。
从今天开始,正式进入项目阶段。本次的项目是跟着黑马的瑞吉外卖项目走的,有借鉴和使用,也有自己的观点和实现。由于本课程用到了很多前端知识(了解),所以关于前端分析的时候,我应该会选择跳过或者简略一看;大家学有余力或者对前端已经轻车熟路的可以自己看看黑马的视频。本次的项目并没有从前端到后台都自己进行搭建,虽然我也很向往这个,但是还是在学精后端再去深入前端吧,我也没有余力,只是后端的内容就已经让我头大了。
在可预见的将来,IT不会萎缩,只会越发展越庞大,最终会渗透到人类社会的每一个角落。在这个过程中会不断地产生新的领域和新的机会,我们则需要在这个风口上抓住机会。从技术层面来说,吃透测试理论和方法,掌握最少一门开发语言,能够熟练使用最少一种自动化、接口或APP测试工具将成为入行的基本要求。从业务层面来说,新兴或热点领域将来带巨大的需求量和丰厚的薪酬,这也要求我们不断的了解新的领域、学习新的知识
vulntarget-b靶场最详细通关记录。
MongoDB是一个开源、高性能、支持海量数据存储的。
【NoSQL数据库技术与应用】课本代码、课后答案(持续更新)
MongoDB 的安装详细过程
Redisredis 简介redis 采用的是单线程的 KV 模型,由 C 语言编写,1. Redis 中的事务?2. Redis 中的数据结构3. Redis 中如何保证缓存和数据库双写时的数据一致性?4. 如何使用 Redis 做异步队列和延时队列?5. Redis 中的过期策略6. Redis 中的内存淘汰机制7. Redis 中的缓存击穿,缓存穿透,缓存雪崩8. Redis 中的分布式锁9. Redis和memcache的区别10. Redis 中的持久化机制11. Red
Redis必背面试题