geospatial
应用场景:
- 地理定位
- 附件的人
- 打车距离计算
常用命令:
- geoadd 添加地理位置,支持可变长度(geoadd china:city 经度 维度 城市名)(只支持有效的经度和维度)
- geopos 获取指定城市经纬度(geopos china:city 城市名)
- geodist 返回两个给定位置之间的距离(geodist china:city beijing shanghai km)(计算的是直线距离,给定了单位km,默认为m)
- georadius 以给定的经度维度为中心,找出某一半径内存在的所有位置 (georadius china:city 110 30 1000 km)可跟withdist 返回直线距离, withcoord 返回他人的经纬度,count num 限定查询数量为num
- georadiusbymember 指定一个位置,找出指定位置指定范围内的元素(georadiusbymember china:city beijing 1000 km )
- geohash 返回一个或多个元素的goehash位置表示,元素为11个字符的geohash字符串,会损失精度 (会将二维的经纬度转换为一维的字符串,如果两个字符串越接近,则距离越近)(geohash china:city beijing chongqing)
geo底层是依靠zset来实现的,可以使用zset来操作geo进行crud
hyperloglog(基数操作)
hyperlogog 是基数统计的算法,用于寻找不重复的元素
优点:占用的内存是固定的,耗费空间小,使用位计算
缺点:数量很大的情况下,有0.81%的错误率
使用场景:
- 网页uv访问
- 如果允许容器可以使用这个,不允许容错就使用set
常用命令:
- pfadd 创建一组元素
- pfcount 统计元素的不重复数量
- pfmerge 合并两组元素生成新的一组元素
bitmaps(位图,位存储类型)
常用场景:
- 统计用户的活跃信息
- 统计登录人数
- 上班打卡
- 具备两个状态的,都可以使用bitmaps
常用方法:
- setbit 设置key-valueInt
- getbit 获得key的值
- bitcount 统计valueInt为1的数量
bitmaps 的valueInt只为0或1,因为只存在0和1两个状态