一、set类型
1.新的存储需求:存储大量的数据,在查询方面提供更高的效率(之前的list类型底层是链表结构,所以在查询方面效率较低)
2.需要的存储结构:能够保存大量的数据,高效的内部存储机制,便于查询
3.set类型:与hash存储结构完全相同,仅存储键,不存储值(nil),并且值是不允许重复的
二、set 类型数据的基本操作
1. 添加数据
sadd key member1 [member2]
2. 获取全部数据
smembers key
3. 删除数据
srem key member1 [member2]
4. 获取集合数据总量
scard key
5. 判断集合中是否包含指定数据
sismember key member
三、set 类型数据的扩展操作
1. 随机获取集合中指定数量的数据
srandmember key [count]
2. 随机获取集合中的某个数据并将该数据移出集合
spop key [count]
场景:应用于随机推荐类信息检索,例如热点歌单推荐,热点新闻推荐,热卖旅游线路,应用APP推荐, 大V推荐等,如随机获取热门新闻中的一条进行推荐,不会影响原来数据,对数据进行随机的展现,活跃应用的业务。
3. 求两个集合的交、并、差集
sinter key1 [key2]
sunion key1 [key2]
sdiff key1 [key2] ---(差集:key1-key2)
4. 求两个集合的交、并、差集并存储到指定集合中
sinterstore destination key1 [key2]
sunionstore destination key1 [key2]
sdiffstore destination key1 [key2]
5. 将指定数据从原始集合中移动到目标集合中
smove source destination member
场景:redis应用于同类信息的关联搜索,二度关联搜索,深度关联搜索
显示共同关注(一度)
显共同好友(一度)
由用户A出发,获取到好友用户B的好友信息列表(一度)
由用户A出发,获取到好友用户B的购物清单列表(二度)
由用户A出发,获取到好友用户B的游戏充值列表(二度)
一度可以理解为你的好友,即第一层
二度可以理解为你好友的***,即间接层面
四、set 类型数据操作的注意事项
1. set 类型不允许数据重复,如果添加的数据在 set 中已经存在,将只保留一份
2. set 虽然与hash的存储结构相同,但是无法启用hash中存储值的空间
五、set类型应用
案列:
公司对旗下新的网站做推广,统计网站的PV(访问量),UV(独立访客),IP(独立IP)。
PV:网站被访问次数,可通过刷新页面提高访问量
UV:网站被不同用户访问的次数,可通过cookie统计访问量,相同用户切换IP地址,UV不变
IP:网站被不同IP地址访问的总次数,可通过IP地址统计访问量,相同IP不同用户访问,IP不变
方案:
利用set集合的数据去重特征,记录各种访问数据
建立string类型数据,利用incr统计日访问量(PV)
建立set模型,记录不同cookie数量(UV)
建立set模型,记录不同IP数量(IP)
模拟:ip为1.2.3.4和2.3.4.5,一个ip不能重复在同一时间在网站进行操作
redis 应用于同类型数据的快速去重
redis 应用于基于黑名单与白名单设定的服务控制