Redis之5———set类型详解:常用操作、业务场景

目录

1 set类型

2 set类型数据的基本操作

1 sadd key member1 [merber2]:添加数据

2 smembers key:获取全部数据

3 srem key member1 [member2]:删除数据

4 scard key:获取集合数据总量

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:将指定数据从原始集合移动到目录集合中

3 set类型数据操作的注意事项

4 业务场景


在可以存放大量数据的list中,由于其底层是用双端对列来实现的,因此,如果数据量真的非常大的话,需要从中间而不是从两端进行操作,那么list的效率是非常低下的。

1 set类型

  • 新的存储需求:存储大量的数据,在查询方面的提供更高的效率。
  • 需要的存储结构:能够保存大量的数据,高效的内部存储机制,便于查询。
  • set类型与hash存储结构完全相同,仅使用键值,不存储值,并且值是不允许重复的。

Redis之5———set类型详解:常用操作、业务场景_第1张图片

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]:随机从集合中获取指定数量的数据,原集合不变

Redis之5———set类型详解:常用操作、业务场景_第2张图片

随机获取wangwu后,集合数据没有发生变化

7 spop key [count] :随机获取集合中的数据,并从集合中移除

可以发现用spop之后,集合内的数据发生了变化。

8 sinter/sunion/sdiff key1 [key2]:求两个集合的交、并、差集

我们有两个集合:u1(a1,s1,b1),u2(s1,w1,)

Redis之5———set类型详解:常用操作、业务场景_第3张图片

注意sdiff是有方向性的。

9  sinterstore/sunionstore/sdiffstore destination key1 [key2]:求两个集合的交、并、差集并存储到指定的集合当中

sinterstore/sunionstore/sdiffstore和 sinter/sunion/sdiff相比,只需要提供一个目标集合即可。

10 smove source destination member:将指定数据从原始集合移动到目录集合中

Redis之5———set类型详解:常用操作、业务场景_第4张图片

可以发现,已经将w1从u2从移动到u1中。

可以

3 set类型数据操作的注意事项

  • set类型不允许数据重复,如果添加的数据已经存在,将只保留一份
  • set虽然与hash的存储结构相同,但是无法启用hash中存储值的空间

4 业务场景

  • redis set可以用于随机推荐类信息检索,例如歌单推荐,热点新闻推荐,热卖旅游线路,应用app、大V推荐等。
  • 向支付宝、qq中的“你的好友xxx和你有x位共同联系人”,“你可能也认识xxx”都可以通过redis set的相关操作来实现。
  • redis set可应用于同类信息的关联搜索。

你可能感兴趣的:(#,redis)