目录
1 sadd key member1 [merber2]:添加数据
3 srem key member1 [member2]:删除数据
5 sismember key member:判断集合中是否包含指定数据
6 srandmember key [count]:随机从集合中获取指定数量的数据,原集合不变
7 spop key [count] :随机获取集合中的数据,并从集合中移除
8 sinter/sunion/sdiff key1 [key2]:求两个集合的交、并、差集
9 sinterstore/sunionstore/sdiffstore destination key1 [key2]:求两个集合的交、并、差集并存储到指定的集合当中
10 smove source destination member:将指定数据从原始集合移动到目录集合中
在可以存放大量数据的list中,由于其底层是用双端对列来实现的,因此,如果数据量真的非常大的话,需要从中间而不是从两端进行操作,那么list的效率是非常低下的。
1 set类型
- 新的存储需求:存储大量的数据,在查询方面的提供更高的效率。
- 需要的存储结构:能够保存大量的数据,高效的内部存储机制,便于查询。
- set类型与hash存储结构完全相同,仅使用键值,不存储值,并且值是不允许重复的。
2 set类型数据的基本操作
由于set不想list要分左右,也不想hash要存储值,因此操作起来非常的简单。
1 sadd key member1 [merber2]:添加数据
2 smembers key:获取全部数据
3 srem key member1 [member2]:删除数据
4 scard key:获取集合数据总量
可以看出users中现在有两个元素
5 sismember key member:判断集合中是否包含指定数据
返回0,因为zhangsan不是users里面的成员
6 srandmember key [count]:随机从集合中获取指定数量的数据,原集合不变
随机获取wangwu后,集合数据没有发生变化
7 spop key [count] :随机获取集合中的数据,并从集合中移除
可以发现用spop之后,集合内的数据发生了变化。
8 sinter/sunion/sdiff key1 [key2]:求两个集合的交、并、差集
我们有两个集合:u1(a1,s1,b1),u2(s1,w1,)
注意sdiff是有方向性的。
9 sinterstore/sunionstore/sdiffstore destination key1 [key2]:求两个集合的交、并、差集并存储到指定的集合当中
sinterstore/sunionstore/sdiffstore和 sinter/sunion/sdiff相比,只需要提供一个目标集合即可。
10 smove source destination member:将指定数据从原始集合移动到目录集合中
可以发现,已经将w1从u2从移动到u1中。
可以
3 set类型数据操作的注意事项
- set类型不允许数据重复,如果添加的数据已经存在,将只保留一份
- set虽然与hash的存储结构相同,但是无法启用hash中存储值的空间
4 业务场景
- redis set可以用于随机推荐类信息检索,例如歌单推荐,热点新闻推荐,热卖旅游线路,应用app、大V推荐等。
- 向支付宝、qq中的“你的好友xxx和你有x位共同联系人”,“你可能也认识xxx”都可以通过redis set的相关操作来实现。
- redis set可应用于同类信息的关联搜索。