Redis三大特殊数据类型

1、Geospatial:地理位置

  • 有效的经度从-180度到180度。

  • 有效的纬度从-85.05112878度到85.05112878度。

  • m 为米、km 为千米、mi 为英里、ft 为英尺。

(1)geoadd(添加)、geopos(查看)、geodist(计算距离)操作

  • 添加地理位置:geoadd key longitude latitude member (可多个添加)

  • 查看经纬度信息: geopos key member [member …]

  • 计算距离:geodist key member1 member2

127.0.0.1:6379> geoadd city 118.8921 31.32751 nanjing 197.30794 31.79322  
#当经纬度其中一个或者两个超过界限值,报错
(error) ERR syntax error. Try GEOADD key [x1] [y1] [name1] [x2] [y2] [name2] ...
#添加成功后返回添加成功的数量值
127.0.0.1:6379> geoadd city 118.8921 31.32751 nanjing 117.30794 31.79322 hefei 102.82147 24.88554 kunming 91.13775 29.65262 lasa 116.23128 40.22077 beijing 106.54041 29.40268 chongqing  
(integer) 6
127.0.0.1:6379> ZRANGE city 0 -1  #geo的查看方式和zset的命令是一致的
1) "lasa"
2) "kunming"
3) "chongqing"
4) "hefei"
5) "nanjing"
6) "beijing"


127.0.0.1:6379> geopos city nanjing  #查看看指定城市的经纬度信息
1) 1) "118.89209836721420288"
   2) "31.32750976275760735"
127.0.0.1:6379> geopos city nanjing beijing  #查看看多个城市的经纬度信息
1) 1) "118.89209836721420288"
   2) "31.32750976275760735"
2) 1) "116.23128265142440796"
   2) "40.22076905438526495"


127.0.0.1:6379> geodist city nanjing beijing   #计算南京到北京之间的距离,默认返回单位是m
"1017743.1413"
127.0.0.1:6379> geodist city nanjing beijing km  #km  千米
"1017.7431"
127.0.0.1:6379> geodist city nanjing beijing mi  #mi  英里
"632.3978"
127.0.0.1:6379> geodist city nanjing beijing ft  #ft  英尺
"3339052.3010"

(2)georadius(查询附近位置)操作

查询指定位置指定范围内的所有信息:georadius key longitude latitude radius m|km|ft|mi

#查看指定位置指定范围内有哪些城市
127.0.0.1:6379> georadius city 120 40 1000 km
1) "beijing"
2) "hefei"
3) "nanjing"
127.0.0.1:6379> georadius city 120 40 300 km
(empty list or set)
127.0.0.1:6379>  georadius city 120 40 400 km
1) "beijing"

#查看指定位置的1000km范围内有哪些城市,withcoord指定返回城市的name
127.0.0.1:6379> georadius city 120 40 1000 km withcoord
1) 1) "beijing"
   2) 1) "116.23128265142441"
      2) "40.220769054385265"
2) 1) "hefei"
   2) 1) "117.30793744325638"
      2) "31.793219150805264"
3) 1) "nanjing"
   2) 1) "118.8920983672142"
      2) "31.327509762757607"

#查看指定位置的1000km范围内有哪些城市,withdist指定返回城市的’经纬度‘值
127.0.0.1:6379> georadius city 120 40 1000 km withcoord withdist
1) 1) "beijing"
   2) "321.5057"
   3) 1) "116.23128265142441"
      2) "40.220769054385265"
2) 1) "hefei"
   2) "944.3486"
   3) 1) "117.30793744325638"
      2) "31.793219150805264"
3) 1) "nanjing"
   2) "969.7654"
   3) 1) "118.8920983672142"
      2) "31.327509762757607"

#查看指定位置的1000km范围内有哪些城市,withhash指定返回城市的’经纬度‘的hash值,hash值越相近,证明城市距离越近
127.0.0.1:6379> georadius city 120 40 1000 km withcoord withdist withhash
1) 1) "beijing"
   2) "321.5057"
   3) (integer) 4069896088584598
   4) 1) "116.23128265142441"
      2) "40.220769054385265"
2) 1) "hefei"
   2) "944.3486"
   3) (integer) 4052763834193093
   4) 1) "117.30793744325638"
      2) "31.793219150805264"
3) 1) "nanjing"
   2) "969.7654"
   3) (integer) 4054278565840695
   4) 1) "118.8920983672142"
      2) "31.327509762757607"

#查看指定位置的1000km范围内有哪些城市,count num 指定返回’num‘个城市数据量
127.0.0.1:6379> georadius city 120 40 1000 km withcoord withdist withhash count 2
1) 1) "beijing"
   2) "321.5057"
   3) (integer) 4069896088584598
   4) 1) "116.23128265142441"
      2) "40.220769054385265"
2) 1) "hefei"
   2) "944.3486"
   3) (integer) 4052763834193093
   4) 1) "117.30793744325638"
      2) "31.793219150805264"

(3)georadiusbymember (查找指定元素指定范围内的元素)、geohash (返回经纬度的hash值)、zrange、zrem(使用zset命令操作geo)

  • 查找指定元素指定范围内的元素:georadiusbymember key member

  • 返回经纬度的hash值:geohash key member [member …]

  • 获取所有元素:zrange key start stop [WITHSCORES]

  • 删除指定元素:zrem key member [member …]

#查询南京 500公里范围有哪些城市
127.0.0.1:6379> georadiusbymember city nanjing 500 km
1) "hefei"
2) "nanjing"
#查询重庆 1500公里范围有哪些城市
127.0.0.1:6379> georadiusbymember city chongqing 1500 km
1) "lasa"
2) "kunming"
3) "chongqing"
4) "hefei"
5) "nanjing"
6) "beijing"

#返回北京和南京的经纬度的 hash值
127.0.0.1:6379> geohash city beijing nanjing
1) "wx4sucvncn0"
2) "wtsd1qyxfx0"

#查看所有城市name
127.0.0.1:6379> ZRANGE city 0 -1
1) "lasa"
2) "kunming"
3) "chongqing"
4) "hefei"
5) "nanjing"
6) "beijing"

#根据geo中的name删除元素
127.0.0.1:6379> ZREM city lasa
(integer) 1
127.0.0.1:6379> ZRANGE city 0 -1
1) "kunming"
2) "chongqing"
3) "hefei"
4) "nanjing"
5) "beijing"

总结:可以用来查询附近的人、计算两人之间的距离等。

2、Hyperloglog:基数

基数:两个数据集中不重复的元素

优点:占用的内存是固定的,2^64个元素,相当于只需要12kb的内存,效率较高。

pfadd、pfcount、pfmegre操作

  • 添加数据集:pfadd key element [element …]

  • 统计数据集:pfcount key [key …]

  • 合并数据集: pfmerge destkey sourcekey [sourcekey …](自动去重)

#添加数据集
127.0.0.1:6379> pfadd dataList 1 2 3 4 5 6 7  
(integer) 1

#统计数据集中的元素
127.0.0.1:6379> pfcount dataList  
(integer) 7

127.0.0.1:6379> pfadd dataList1 4 5 6 7 8 9 10 
(integer) 1
127.0.0.1:6379> pfcount dataList1
(integer) 7
#将dataList 和dataList1  两个数据集合并成一个新的 newdata数据集,并且自动去重
127.0.0.1:6379> pfmerge newdata dataList dataList1  
OK
127.0.0.1:6379> pfcount newdata
(integer) 10

总结:实际业务中,例如网站访问量这类允许一定误差的,可以采用基数统计。

3、Bitmap:位存储

操作二进制位来进行记录,只有0 和 1 两个状态。

setbit(添加)、getset(获取)、bitcount(统计)操作

  • 添加状态:setbit key offset value

  • 获取状态:getset key value

  • 统计操作:bitcount key [start end]

127.0.0.1:6379> setbit login 1 1   #添加周一已登陆 为1
(integer) 0
127.0.0.1:6379> setbit login 2 1
(integer) 0
127.0.0.1:6379> setbit login 3 1
(integer) 0
127.0.0.1:6379> setbit login 4 0  #添加周四未登陆 为0
(integer) 0
127.0.0.1:6379> getbit login 1  #获取周一是否登录
(integer) 1
127.0.0.1:6379> getbit login 4  #获取周四是否登陆
(integer) 0
127.0.0.1:6379> bitcount login  #统计本周登录天数
(integer) 3

总结:实际业务中,统计用户的登陆信息,员工的打卡信息等两个状态的,可以使用位存储来操作。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值