redis入门到精通系列(七):redis高级数据类型详解(BitMaps,HyperLogLog,GEO)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了redis入门到精通系列(七):redis高级数据类型详解(BitMaps,HyperLogLog,GEO),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1944字,纯文字阅读大概需要3分钟。
内容图文
高级数据类型和五种基本数据类型不同,并非新的数据结构。高级数据类型往往是用来解决一些业务场景。
(一)BitMaps
(1.1) BitMaps概述
在应用场景中,有一些数据只有两个属性,比如是否是学生,是否是党员等等,对于这些数据,最节约内存的方式就是用bit去记录,以是否是学生为例,1代表是学生,0代表不是学生。那么1000110就代表7个人中3个是学生,这就是BitMaps的存储需求。
Bitmaps是一个可以对位进行操作的字符串,我们可以把Bitmaps想象成是一串二进制数字,每个位置只存储0和1。下标是Bitmaps的偏移量(offset)
(1.2) BitMaps操作
getbit key offset
设置指定key对应偏移量上的bit值,value只能是1或0
setbit key offset value
对指定key按位进行交、并、非、异或操作,并把结果保存到destKey中
bitop and destKey key1 key2.... //交 bitop or destKey key1 key2.... //并 bitop not destKey key1 key2.... //非 bitop xor destKey key1 key2.... //异或
bitcount key startend
(1.3) BitMaps应用场景
我们假设一家公司要统计他们所有注册会员的每日/每周/每年登陆网站的情况,就可以使用BitMaps。其中每日登陆会员数量的统计方法如下:建立一个key值为当前日期的BitMaps,当id为5的会员登陆时,设置偏移量为4(下标从0开始),将BitMaps偏移量为4的数设置为1,以此类推。统计每日登陆的会员数就用bitcount命令统计即可。
统计每周登陆会员数量的方法如下:对于统计每周登陆会员数,只需要将一周7天的数据使用并(or)操作计算即可。一个会员只要有一天的值等于1,那么并操作之后他的值就等于1,说明这一周他登陆了。再用bitcount统计即可。
(二)HyperLogLog
HyperLogLog是用来做基数统计的,所谓基数统计,就是指一串数字中不重复的数字个数,如{1,2,1,2,3}的基数就是3。
pfadd key element1 element2...
pfcount key1 key2...
pfmerge destkey sourcekey1 sourcekey2...
占用空间很小,每个hyperLogLog只占用12k的内存。
pfadd命令不是一次性分配12k的数据,会随着基数的增加内存逐渐增大。
pfmerge命令合并后占用的存储空间为12k,无论之前的数据量为多少。
(三)GEO
GEO是redis中关于地理位置计算的高级数据类型,比如微信中的附近好友会展示好友离你的距离,这就是GEO的一个应用。
geoadd key longitude latitude member [longitude latitude member...]
geopos key member
geodist key member1 member2 [unit] unit表示单位,默认m,可以设置 km, ft, mi
根据坐标求范围内的数据(withcoord显示坐标,withdist显示距离,withhash显示hash值,count count用来取范围)
georadius key longitude latitude radius m|km|ft|mi [withcoord] [withdist] [withhash] [countcount]
georadiusbymember key member radius m|km|ft|mi [withcoord] [withdist] [withhash] [countcount]
geohash key member1 member2...
原文:https://www.cnblogs.com/edda/p/13068237.html
内容总结
以上是互联网集市为您收集整理的redis入门到精通系列(七):redis高级数据类型详解(BitMaps,HyperLogLog,GEO)全部内容,希望文章能够帮你解决redis入门到精通系列(七):redis高级数据类型详解(BitMaps,HyperLogLog,GEO)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。