GEORADIUS key longitude latitude radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [ASC|DESC] [COUNT count]
以给定的经纬度为中心, 返回键包含的位置元素当中, 与中心的距离不超过给定最大距离的所有位置元素。
范围可以使用以下其中一个单位:
m
表示单位为米。km
表示单位为千米。mi
表示单位为英里。ft
表示单位为英尺。在给定以下可选项时, 命令会返回额外的信息:
WITHDIST
:
在返回位置元素的同时,
将位置元素与中心之间的距离也一并返回。
距离的单位和用户给定的范围单位保持一致。WITHCOORD
:
将位置元素的经度和维度也一并返回。WITHHASH
:
以 52 位有符号整数的形式,
返回位置元素经过原始 geohash 编码的有序集合分值。
这个选项主要用于底层应用或者调试,
实际中的作用并不大。命令默认返回未排序的位置元素。 通过以下两个参数, 用户可以指定被返回位置元素的排序方式:
ASC
:
根据中心的位置,
按照从近到远的方式返回位置元素。DESC
:
根据中心的位置,
按照从远到近的方式返回位置元素。在默认情况下,
GEORADIUS
命令会返回所有匹配的位置元素。
虽然用户可以使用 COUNT <count>
选项去获取前 N 个匹配元素,
但是因为命令在内部可能会需要对所有被匹配的元素进行处理,
所以在对一个非常大的区域进行搜索时,
即使只使用 COUNT
选项去获取少量元素,
命令的执行速度也可能会非常慢。
但是从另一方面来说,
使用 COUNT
选项去减少需要返回的元素数量,
对于减少带宽来说仍然是非常有用的。
GEORADIUS
命令返回一个数组,
具体来说:
WITH
选项的情况下,
命令只会返回一个像 ["New York","Milan","Paris"]
这样的线性(linear)列表。WITHCOORD
、 WITHDIST
、 WITHHASH
等选项的情况下,
命令返回一个二层嵌套数组,
内层的每个子数组就表示一个元素。在返回嵌套数组时, 子数组的第一个元素总是位置元素的名字。 至于额外的信息, 则会作为子数组的后续元素, 按照以下顺序被返回:
举个例子,
GEORADIUS Sicily 15 37 200 km withcoord withdist
这样的命令返回的每个子数组都是类似以下格式的:
["Palermo","190.4424",["13.361389338970184","38.115556395496299"]]
redis> GEOADD Sicily 13.361389 38.115556 "Palermo" 15.087269 37.502669 "Catania"
(integer) 2
redis> GEORADIUS Sicily 15 37 200 km WITHDIST
1) 1) "Palermo"
2) "190.4424"
2) 1) "Catania"
2) "56.4413"
redis> GEORADIUS Sicily 15 37 200 km WITHCOORD
1) 1) "Palermo"
2) 1) "13.361389338970184"
2) "38.115556395496299"
2) 1) "Catania"
2) 1) "15.087267458438873"
2) "37.50266842333162"
redis> GEORADIUS Sicily 15 37 200 km WITHDIST WITHCOORD
1) 1) "Palermo"
2) "190.4424"
3) 1) "13.361389338970184"
2) "38.115556395496299"
2) 1) "Catania"
2) "56.4413"
3) 1) "15.087267458438873"
2) "37.50266842333162"