Redis数据结构之set
卑微小吴励志写博客第21天。
前几天因为有事情耽误了没有更新博客,就感觉是没完成作业一样,希望自己这个习惯还是放弃了,所以还是坚持写。
set
set这个数据结构是为了完成存储大量数据,并且可以快速找到而诞生的。list在前面介绍了,是一个链表结构,在查询数据的时候还是存在缺陷,set的结构和hash完全一样,只是在hash中存放key的位置变为存值,value的位置不放任何东西。
set的基本操作
添加数据
- sadd key member1 【menber2】
获取全部数据
- smembers key
删除数据
- srem key member1 [member2]
获取数量总和,有多少数据
- scard key
判断集合中是否有数据
- sismember key member
set的扩展数据
业务场景
解决方案
随机获取集合中指定数量的数据
- srandmember key [count]
随机获取集合中的数据并将该数据移除出集合
- spop key
tips
redis可以用于随机推荐类信息检索,例如热点歌单,热点新闻推荐,热点旅游路线,应用APP推荐,大V推荐。
业务场景2
set的交并差集
求两个集合的交、并、差集
- sinter key1 [key2]
- sunion key1 [key2]
- sdiff key1 [key2]
求两个集合的交并差集并存储到指定集合
- sinterstore destination key1 [key2]
- sunionstore destination key1 [key2]
- sdiffstore destination key1 [key2]
将指定数据从一个集合移动到另一个集合
- smove source destination member
- 注意:这里的destination代表的是目标集合名称
tips
- redis应用于同类信息的关联搜索,二度关联搜索,深度关联搜索。
- 显示共用关注。(一度)
- 显示共同好友。(一度)
- 由用户A出发,获取到好友用户B的好友信息列表。(一度)
- 由用户A出发, 获取到好友B的购物清单列表。(二度)
- 由用户A出发,获取到用户B的游戏充值列表。(二度)
set类型数据操作的注意事项
- set类型不允许数据重复,如果添加的数据在set中已经存在,将添加不进去,只保留一份。
- set虽然和hash的数据结构一样,但是无法启用hash中存储值的空间。
这里实际的场景中肯定不是这样做的,这里只是说redis可以完成这件事。实际spring框架中就有权限校验的一些实现方式。
有些案例需要大家自己动手去构建,然后品味一下,才能真正理解。今天就介绍到这里了。