八:Redis-Hyperlog基数统计详解和Bitmap位图场景详解

Hyperlog

基数

A{1 2 3 4 5}
B{4 5 6 7 8}
基数:8(统计去除重复元素的个数)

优点

占用内存是固定的,只需要占用12kb的内存!但是有0.81%的错误率,用于统计网页访问人数是可以接受度的。

  1. 基数统计
127.0.0.1:6379> pfadd key1 1 2 3 4 5 #向key1中添加值
(integer) 1
127.0.0.1:6379> pfcount key1 #统计key1值的个数
(integer) 5
127.0.0.1:6379>  pfadd key2 4 5 6 7 8 #向key2中添加值
(integer) 1
127.0.0.1:6379> pfcount key2 #统计key2值的个数
(integer) 5
#统计key1和key2的基数放入key3{1 2 3 4 5 6 7 8 }中
127.0.0.1:6379> pfmerge key3 key1 key2 
OK
127.0.0.1:6379> pfcount key3#查看新生成key3中个数
(integer) 8
127.0.0.1:6379>

小结:
如果允许容错,则使用Hyperlog;如果不允许容错,则使用set或者zset

Bitmap

位存储

统计用户信息是否活跃,是否经常登录,是否打卡,两种状态的。Bitmap位图都是操作二进制来进行记录,只有0和1两个状态

  1. 查看用户一个星期的打卡情况

语法:setbit key offset value 且offset 和value必须为数字,value必须为数字0或1

#记录attendence中周日(0代表周日)未出勤(0代表未出勤)
127.0.0.1:6379> setbit attendence 0 0
(integer) 0
#记录attendence中周日(1代表周一)出勤(1代表未出勤)
127.0.0.1:6379> setbit attendence 1 1
(integer) 0
#记录attendence中周日(2代表周二)出勤(1代表未出勤)
127.0.0.1:6379> setbit attendence 2 1
(integer) 0
#记录attendence中周日(3代表周三)出勤(1代表未出勤)
127.0.0.1:6379> setbit attendence 3 1
(integer) 0
127.0.0.1:6379> setbit attendence 4 1
(integer) 0
127.0.0.1:6379> setbit attendence 5 1
(integer) 0
#记录attendence中周六(6代表周六)未出勤(0代表未出勤)
127.0.0.1:6379> setbit attendence 6 0
(integer) 0
127.0.0.1:6379>
  1. 查看某天是否打卡
127.0.0.1:6379> getbit attendence 0#查看周日是否出勤,未出勤则返回0
(integer) 0
127.0.0.1:6379> getbit attendence 3 #查看周四是否出勤,出勤则返回1
(integer) 1
127.0.0.1:6379>
  1. 统计操作
127.0.0.1:6379> bitcount attendence #统计出勤天数
(integer) 5
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值