欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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

程序员文章站 2022-07-11 14:58:53
...

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