天天看点

八: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
           

继续阅读