15. redis的GEO功能

本文介绍了GEO(地理信息定位)在Redis中的实现与应用,包括如何存储经纬度、计算两地距离及范围计算等。文章详细解释了GEO相关的Redis命令,如geoadd、geopos、geodist、georadius和georadiusbymember,并指出这些功能自redis3.2版本开始支持。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

GEO

什么是GEO

GEO(地理信息定位),存储经纬度,计算两地距离,范围计算等

相关命令

api说明
geoadd key longitude latitude member增加地理位置信息,member是一个表示
geopos key member获取地理位置信息
geodist key member1 member2 [unit]获取两个地理位置的距离,unit:m(米)、km(千米)、mi(英里)、ft(尺)

georadius key longitude latitude radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [COUNT count] [asc|desc] [store key] [storedist key]
以给定的经纬度为中心, 返回键包含的位置元素当中, 与中心的距离不超过给定最大距离的所有位置元素
范围可以使用以下其中一个单位:
m 表示单位为米。
km 表示单位为千米。
mi 表示单位为英里。
ft 表示单位为英尺。
WITHDIST: 在返回位置元素的同时, 将位置元素与中心之间的距离也一并返回。 距离的单位和用户给定的范围单位保持一致。
WITHCOORD: 将位置元素的经度和维度也一并返回。
WITHHASH: 以 52 位有符号整数的形式, 返回位置元素经过原始 geohash 编码的有序集合分值。 这个选项主要用于底层应用或者调试, 实际中的作用并不大。
ASC: 根据中心的位置, 按照从近到远的方式返回位置元素。
DESC: 根据中心的位置, 按照从远到近的方式返回位置元素。
store key: 将返回结果的地理位置信息保存到指定key
storedist key:将返回结果距离中心节点的距离保存到指定key

GEORADIUSBYMEMBER key member radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [COUNT count] [asc|desc] [store key] [storedist key]
这个命令和 GEORADIUS 命令一样, 都可以找出位于指定范围内的元素, 但是 GEORADIUSBYMEMBER 的中心点是由给定的位置元素决定的。

相关说明

  1. redis 3.2+
  2. GEO 使用zset实现
  3. 没有删除API,使用zrem key member 实现
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值