4、Redis:三种特殊数据类型

4.1、geospatial地理位置

朋友的定位、附近的人、打车距离计算?

Reids的Geo在Redis3.2版本就推出了!这个功能可以推算地理位置的信息,两地之间的距离,方圆几里的人!

可以查询一些测试数据:http://www.jsons.cn/lngcode/

只有六个命令
在这里插入图片描述

4.1.1、GEOADD

# getadd 添加地理位置
# 有效的经度:-180度到180度
# 有效的纬度:-85.05112878度到85.05112878度
# 当坐标位置超过上述指定范围时,该命令将会返回一个错误
# 规则:两极无法直接添加,我们一般会下载城市数据,直接通过java程序一次性导入!
# 参数 geoadd china:city 经度 纬度 beijing
127.0.0.1:6379> geoadd china:city 116.40 39.90 beijing
(integer) 1
127.0.0.1:6379> geoadd china:city 121.47 31.23 shanghai
(integer) 1
127.0.0.1:6379> geoadd china:city 103.82 36.05 lanzhou
(integer) 1
127.0.0.1:6379> geoadd china:city 105.30 34.01 xihe
(integer) 1
127.0.0.1:6379> geoadd china:city 117.19 39.12 tianjin
(integer) 1
127.0.0.1:6379> geoadd china:city 108.94 34.26 xian
(integer) 1

4.1.2、GEOPOS

获得当前定位:一定是一个坐标值!

127.0.0.1:6379> geopos china:city lanzhou # 获取指定的经度和纬度
1) 1) "103.81999880075454712"
   2) "36.04999944914519006"
127.0.0.1:6379> geopos china:city beijing
1) 1) "116.39999896287918091"
   2) "39.90000009167092543"
127.0.0.1:6379> geopos china:city xihe xian
1) 1) "105.29999881982803345"
   2) "34.01000009624369369"
2) 1) "108.93999785184860229"
   2) "34.25999964418929977"

4.1.3、GEODIST

两人之间的距离

单位:

  • m 表示单位为米
  • km 表示单位为千米
  • mi 表示单位为英里
  • ft 表示单位为英尺
127.0.0.1:6379> geodist china:city lanzhou tianjin
"1225587.2934" # 查看兰州到天津的距离
127.0.0.1:6379> geodist china:city lanzhou tianjin km
"1225.5873"  # 查看兰州到天津的距离,单位为km
127.0.0.1:6379> geodist china:city lanzhou xihe km
"263.9110"  # 查看兰州到西和的距离,单位为km

4.1.4、GEORADIUS

以给定的经纬度为中心,找出某一半径内的元素

我附近的人?(获得所有附近的人的地址,定位!)通过半径来查询!

所有数据都应该录入:china:city,才会让结果更加清晰

127.0.0.1:6379> georadius china:city 110 30 1000 km # 以110 30 这个经纬度为中心,寻找方圆1000km以内的城市
1) "xihe"
2) "lanzhou"
3) "xian"
127.0.0.1:6379> georadius china:city 110 30 500 km
1) "xian"
127.0.0.1:6379> georadius china:city 110 30 500 km withdist   # 以110 30 这个经纬度为中心,寻找方圆500km以内的城市,并显示到中心距离的位置
1) 1) "xian"
   2) "484.2186"
127.0.0.1:6379> georadius china:city 110 30 500 km withcoord # 以110 30 这个经纬度为中心,寻找方圆500km以内的城市,并显示经度维度
1) 1) "xian"
   2) 1) "108.93999785184860229"
      2) "34.25999964418929977"
127.0.0.1:6379> georadius china:city 110 30 1000 km withdist withcoord count 1 # 筛选出指定结果的个数
1) 1) "xian"
   2) "484.2186"
   3) 1) "108.93999785184860229"
      2) "34.25999964418929977"
127.0.0.1:6379> georadius china:city 110 30 1000 km withdist withcoord count 2
1) 1) "xian"
   2) "484.2186"
   3) 1) "108.93999785184860229"
      2) "34.25999964418929977"
2) 1) "xihe"
   2) "628.6854"
   3) 1) "105.29999881982803345"
      2) "34.01000009624369369"
127.0.0.1:6379> georadius china:city 110 30 1000 km withdist withcoord count 3
1) 1) "xian"
   2) "484.2186"
   3) 1) "108.93999785184860229"
      2) "34.25999964418929977"
2) 1) "xihe"
   2) "628.6854"
   3) 1) "105.29999881982803345"
      2) "34.01000009624369369"
3) 1) "lanzhou"
   2) "885.5336"
   3) 1) "103.81999880075454712"
      2) "36.04999944914519006"
127.0.0.1:6379> georadius china:city 110 30 1000 km withdist withcoord count 4
1) 1) "xian"
   2) "484.2186"
   3) 1) "108.93999785184860229"
      2) "34.25999964418929977"
2) 1) "xihe"
   2) "628.6854"
   3) 1) "105.29999881982803345"
      2) "34.01000009624369369"
3) 1) "lanzhou"
   2) "885.5336"
   3) 1) "103.81999880075454712"
      2) "36.04999944914519006"

4.2.5、GEORADIUSBYMEMBER

# 找出位于指定元素周围的其他元素
127.0.0.1:6379> GEORADIUSBYMEMBER china:city beijing 1000 km 
1) "tianjin"
2) "beijing"
3) "xian"
127.0.0.1:6379> GEORADIUSBYMEMBER china:city lanzhou 400 km
1) "xihe"
2) "lanzhou"

4.1.6、GEOHASH

该命令将返回11个字符的Geohash字符串!

# 将二位的经纬度转换为一维的字符串,如果两个字符串越接近,那么则距离越近!
127.0.0.1:6379> geohash china:city beijing tianjin
1) "wx4fbxxfke0"
2) "wwgqd9x4sb0"

4.1.7Geo底层

GEO底层的实现原理其实就是Zset! 我们可以使用Zset命令来操作geo!

127.0.0.1:6379> zrange china:city 0 -1 # 查看地图中全部的元素
1) "xihe"
2) "lanzhou"
3) "xian"
4) "shanghai"
5) "tianjin"
6) "beijing"
127.0.0.1:6379> zrem china:city beijing # 移除指定元素
(integer) 1
127.0.0.1:6379> zrange china:city 0 -1
1) "xihe"
2) "lanzhou"
3) "xian"
4) "shanghai"
5) "tianjin"

4.2、hyperloglog

什么是基数?
比如数据集 {1, 3, 5, 7, 5, 7, 8}, 那么这个数据集的基数集为 {1, 3, 5 ,7, 8}, 基数(不重复元素)为5。
基数估计就是在误差可接受的范围内,快速计算基数。

4.2.1、简介

Redis 2.8.9 版本就更新了hyperloglog 数据结构!

Redis Hyperloglog 技术统计的算法!

优点:占用的内存是固定的,2^64不同的元素的基数,只需要废12KB内存!如果要从内存角度来比较的话Hyperloglog首选!

网页的UV(一个人访问一个网站多次,但是还是算作一个人!)

传统的方式,set保存用户的id,然后就可以统计set中的元素数量作为标准判断!

这个方式如果保存大量的用户id,就会比较麻烦!我们的目的是为了计数,而不是保存用户id;

0.81%错误率! 系统UV任务,可以忽略不计的。

4.2.2、测试

127.0.0.1:6379> PFADD mykey a b c d e f g h i j # 创建第一组元素 mykey
(integer) 1
127.0.0.1:6379> pfcount mykey # 统计 mykey 元素的基数数量
(integer) 10
127.0.0.1:6379> pfadd mykey2 i j z x c v b n m # 创建第二组元素 mykey2
(integer) 1
127.0.0.1:6379> pfcount mykey2
(integer) 9
127.0.0.1:6379> pfmerge mykey3 mykey mykey2 # 合并两组 mykey mykey2 =》 mykey3 并集
OK
127.0.0.1:6379> pfcount mykey3 # 看并集的数量
(integer) 15

如果允许容错,那么一定可以使用Hyperloglog

如果不允许容错,就使用set或者自己的数据类型即可!

4.3、Bitmap

4.3.1、位存储

统计用户信息,活跃,不活跃! 登录、未登录!打卡,365打卡!两个状态的都可以使用Bitmaps位图,数据结构!都是操作二进制位来进行记录,就只有0和1两个状态!

365天 = 356 bit 1字节 = 8bit 46个字节左右!

4.3.2、测试

使用bitmap来记录,周一到周日的打卡!

周一:1 周二:0 周三:0 周四:0

127.0.0.1:6379> setbit sign 0 1
(integer) 0
127.0.0.1:6379> setbit sign 1 0
(integer) 0
127.0.0.1:6379> setbit sign 2 0
(integer) 0
127.0.0.1:6379> setbit sign 3 0
(integer) 0
127.0.0.1:6379> setbit sign 4 1
(integer) 0
127.0.0.1:6379> setbit sign 5 1
(integer) 0
127.0.0.1:6379> setbit sign 6 0
(integer) 0

查看某一天是否有打卡!

127.0.0.1:6379> getbit sign 3
(integer) 0
127.0.0.1:6379> getbit sign 6 
(integer) 0

统计操作,统计打卡的天数!

127.0.0.1:6379> bitcount sign # 统计这周的打卡记录,就可以看到是否有全勤!
(integer) 3

学校视频连接:https://www.bilibili.com/video/BV1S54y1R7SB?p=20

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值