7.redis三大特殊数据类型

1.geospatial:地理位置

redis得geo在3.2版本后已经推出

2.Hyperloglog:专业做网站计数的或页面统计的(允许一定的错误)

redis2.8.9推出了该数据结构
reid  Hyperloglog基数统计的算法
优点:占用的内存是固定,2^64不通元素的技术,只需要占用12kb的内存,如果要从内存角度比较的话:Hyperloglog是首选
使用场景:网页的uv(统计网页的访问量:一个人访问一个网站多次,但是还是算作一个人)         
传统的方式:set保存大量的用户的id,然后可以统计set中元素的数量作为标准判断!
这个方式如果保存大量的用户id,就会比较麻烦!我们的目的是为了计数,而不是保存用户id!
Hyperloglog的统计方式可能会存在0.81%的误差
    使用如下:
        127.0.0.1:6379> PFADD mykey a b c d e  g(创建了一个mykey 的Hyperloglog,并放入6个不重复的元素)
            (integer) 1
        127.0.0.1:6379> PFCOUNT mykey(获取mykey中的元素个数)
            (integer) 6
        127.0.0.1:6379> PFADD mykey1 e g h i j  k(创建另外一个Hyperloglog)
            (integer) 1
        127.0.0.1:6379> PFCOUNT mykey1
            (integer) 6
        127.0.0.1:6379> PFMERGE mykey3 mykey mykey1(将两个Hyperloglog合并为一个mykey3,获取mykey3的不重复元素的数量)
            OK
        127.0.0.1:6379> PFCOUNT mykey3
            (integer) 10

3.bitmap

位存储
只有两个数据结构:0 1的
使用场景:统计用户打卡次数,活跃与不活跃天数等

使用案例:模拟一周打卡,打卡为0 ,没打卡为1
    127.0.0.1:6379> SETBIT sign 0 1(存放一周的打卡状态)
        (integer) 0
    127.0.0.1:6379> SETBIT sign 1 1
        (integer) 0
    127.0.0.1:6379> SETBIT sign 2 0
        (integer) 0
    127.0.0.1:6379> SETBIT sign 3 1
        (integer) 0
    127.0.0.1:6379> SETBIT sign 4 0
        (integer) 0
    127.0.0.1:6379> SETBIT sign 5 0
        (integer) 0
    127.0.0.1:6379> SETBIT sign 6 0
        (integer) 0
    127.0.0.1:6379> GETBIT sign 4(获取周五的打卡状态)
        (integer) 0
    127.0.0.1:6379> GETBIT sign 0(获取周一的打卡状态)
        (integer) 1
    127.0.0.1:6379> BITCOUNT sign(统计一周打卡的次数)
        (integer) 3
    127.0.0.1:6379> BITCOUNT sign 0 5(指定0-5状态为1的次数)
        (integer) 3

 

posted @ 2022-05-25 21:30  努力的达子  阅读(73)  评论(0编辑  收藏  举报