推广 热搜: 公司  快速  上海  中国  企业    未来  政策  系统  公司2 

07-三大特殊数据类型

   日期:2025-01-11     作者:yz0vs4    caijiyuan   评论:0    移动:http://www78564.xrbh.cn/mobile/news/32260.html
核心提示:#添加地理位置 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

#添加地理位置

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 106.50 29.53 chongqing

(integer) 1

127.0.0.1:6379> geoadd china:city 114.05 22.52 shenzhen

(integer) 1

127.0.0.1:6379> geoadd china:city 120.16 30.24 hangzhou

(integer) 1

127.0.0.1:6379> geoadd china:city 108.96 34.26 xian

(integer) 1

127.0.0.1:6379>

geopos

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

#获取指定的城市的经纬度

127.0.0.1:6379> GEOPOS china:city beijing

    1. “116.39999896287918091”
  1. “39.90000009167092543”

127.0.0.1:6379> GEOPOS china:city beijing chongqing

    1. “116.39999896287918091”
  1. “39.90000009167092543”

    1. “106.49999767541885376”
  2. “29.52999957900659211”

127.0.0.1:6379>

geodist

两人的距离

单位:

  • m表示单位为米。

  • km表示单位为千米。

  • mi表示单位为英里。

  • ft表示单位为英尺。

127.0.0.1:6379> geodist china:city beijing shanghai

“1067378.7564”

127.0.0.1:6379> geodist china:city beijing shanghai km #查看上海到北京的直线距离

“1067.3788”

127.0.0.1:6379> geodist china:city beijing chongqing km #查看重庆到北京的直线距离

“1464.0708”

127.0.0.1:6379>

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

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

获得指定数量的人 ,200

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

127.0.0.1:6379> GEORADIUS china:city 110 30 1000 km # 以110 30 这个经纬度为中心,寻找方圆1000km内的城市

  1. “chongqing”

  2. “xian”

  3. “shenzhen”

  4. “hangzhou”

127.0.0.1:6379> GEORADIUS china:city 110 30 500 km

  1. “chongqing”

  2. “xian”

127.0.0.1:6379> GEORADIUS china:city 110 30 500 km withdist #显示到中心距离的位置

    1. “chongqing”
  1. “341.9374”

    1. “xian”
  2. “483.8340”

127.0.0.1:6379> GEORADIUS china:city 110 30 500 km withcoord #显示他人的定位信息

    1. “chongqing”
    1. “106.49999767541885376”
  1. “29.52999957900659211”

    1. “xian”
    1. “108.96000176668167114”
  2. “34.25999964418929977”

127.0.0.1:6379> GEORADIUS china:city 110 30 500 km withdist withcoord count 1 #筛选指定的结果 只要1个

    1. “chongqing”
  1. “341.9374”

    1. “106.49999767541885376”
  2. “29.52999957900659211”

127.0.0.1:6379> GEORADIUS china:city 110 30 500 km withdist withcoord count 2

    1. “chongqing”
  1. “341.9374”

    1. “106.49999767541885376”
  2. “29.52999957900659211”

    1. “xian”
  3. “483.8340”

    1. “108.96000176668167114”
  4. “34.25999964418929977”

127.0.0.1:6379> GEORADIUS china:city 110 30 500 km withdist withcoord count 3

    1. “chongqing”
  1. “341.9374”

    1. “106.49999767541885376”
  2. “29.52999957900659211”

    1. “xian”
  3. “483.8340”

    1. “108.96000176668167114”
  4. “34.25999964418929977”

127.0.0.1:6379>

GEORADIUSBYMEMBER

127.0.0.1:6379> GEORADIUSBYMEMBER china:city beijing 1000 km #找出指定位置的周围城市

  1. “beijing”

  2. “xian”

127.0.0.1:6379> GEORADIUSBYMEMBER china:city shanghai 400 km

  1. “hangzhou”

  2. “shanghai”

127.0.0.1:6379>

geohash命令 返回一个或多个位置元素的geohash表示

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

127.0.0.1:6379> GEOHASH china:city beijing chongqing

  1. “wx4fbxxfke0”

  2. “wm5xzrybty0”

127.0.0.1:6379>

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

127.0.0.1:6379> zrange china:city 0 -1 #查看地图中所有元素

  1. “chongqing”

  2. “xian”

  3. “shenzhen”

  4. “hangzhou”

  5. “shanghai”

  6. “beijing”

127.0.0.1:6379> zrem china:city beijing #移除一个元素

(integer) 1

127.0.0.1:6379> zrange china:city 0 -1

  1. “chongqing”

  2. “xian”

  3. “shenzhen”

  4. “hangzhou”

  5. “shanghai”

127.0.0.1:6379>

Hyperloglog

什么是基数

A{1,3,5,7,8,7}

B{1,3,5,7,8}

基数(不重复的元素=5,可以接受误差

简介

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

Redis Hyperloglog基数统计的算法!

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

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

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

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

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

127.0.0.1:6379> PFADD mykey a b c d e f g #创建第一组元素

mykey(integer) 1

127.0.0.1:6379> pfcount mykey # 统计mykey元素的基数数量

(integer) 7

127.0.0.1:6379> pfadd mykey2 a s d f g h j k l #创建第二组元素 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) 12

127.0.0.1:6379>

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

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

Bitmaps

位存储

统计用户信息,活跃,不活跃!登录、未登录!打卡,365打卡!两个状态的,都可以使用 Bitmaps !

Bitmaps位图,数据结构!都是操作二进制位来进行记录,就只有0和1两个状态!

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

测试

127.0.0.1:6379> setbit sign 0 1 # 周一打卡 0代表没打卡 1代表打卡了

(integer) 0

本文地址:http://www78564.xrbh.cn/news/32260.html    迅博思语 http://www78564.xrbh.cn/ , 查看更多

特别提示:本信息由相关用户自行提供,真实性未证实,仅供参考。请谨慎采用,风险自负。

 
 
更多>同类最新资讯
0相关评论

文章列表
相关文章
最新动态
推荐图文
最新资讯
点击排行
网站首页  |  二维码  |  关于我们  |  联系方式  |  使用协议  |  版权隐私  |  网站地图  |  排名推广  |  广告服务  |  积分换礼  |  网站留言  |  RSS订阅  |  违规举报  |  粤ICP备2023022329号