Redis 之 Geospatial,助你轻松实现附近的 xx 功能
一、简介
Geospatial 是 Redis 在 3.2 版本以后增加的地理位置 GEO 模块,这个模块可以用来实现微信附近的人,在线点餐“附近的餐馆”等位置功能。
二、命令
2.1 GEOADD
命令简介:
GEOADD key longitude latitude member [longitude latitude member …]
将给定的空间元素(维度、经度、名字)添加到指定的键里面,数据以有序集合的形式被存放在键中。GEOADD 接收的参数必须先输入经度,然后输入维度。
GEOADD 经纬度的输入范围如下(对两极不支持):
有效经度介于-180°~180°之间
有效维度介于-85.05112878°至 85.05112878°之间
当用户尝试输入一个超出范围的经度或者纬度时, GEOADD 命令将返回一个错误。
代码示例:可以依次添加单个,也可以同时添加多个地理位置的元素。
错误示例:
2.2 GEOPOS
命令简介:
GEOPOS key member [member …]
根据键(key)获取给定位置元素的位置(经度和纬度),GEOPOS 可以接收一个 member,也可以接收多个 member,如果 member 不存在则返回 nil
代码示例:
2.3 GEODIST
命令简介:
GEODIST key member1 member2 [unit]
返回两个给定位置之间的距离,以双精度浮点数的形式被返回。如果给定的位置其中一个不存在(两个都不存在也是一样,下面有示例),将会返回空值(nil)。
unit 单位描述:
m -> 米
km -> 千米
mi -> 英里
ft -> 英尺
默认单位:如果用户未给定指定单位 unit,则默认为米(m)
误差范围:GEODIST 计算的算法会将地球考虑为一个完全球体,在极限情况下,存在最大 0.5%的误差
代码示例:
2.4 GEORADIUS
命令简介:
GEORADIUS key longitude latitude radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [ASC|DESC] [COUNT count]
以给定的经纬度为中心, 返回键包含的位置元素当中, 与中心的距离不超过给定最大距离的所有位置元素。
m|km|ft|mi 选项:
m -> 米
km -> 千米
mi -> 英里
ft -> 英尺
[WITHCOORD] [WITHDIST] [WITHHASH]选项:
[WITHCOORD]:将位置元素的经度和纬度也一并返回。
[WITHDIST] :在返回位置元素的同时, 将位置元素与中心之间的距离也一并返回。 距离的单位和用户给定的范围单位保持一致。
[WITHHASH]: 以 52 位有符号整数的形式, 返回位置元素经过原始 geohash 编码的有序集合分值。 这个选项主要用于底层应用或者调试, 实际中的作用并不大。
[ASC|DESC] 选项:
ASC:根据给定的中心位置,从近到远返回位置元素
DESC:根据给定的中心位置,从远到近返回位置元素
[COUNT count] 参数:GEORADIUS 默认会返回符合条件的全部位置元素。但是用户可以通过[COUNT count] 参数去指定获取前 N 个匹配元素。这个参数可以减少需要返回的元素数量,一定程度上可以减少带宽压力。
返回值:GEORADIUS 的返回值是一个数组,但是数组的内容会根据是否存在上述参数而改变
未给定任何 WITH 参数,则返回普通线性列表
给定[WITHCOORD] [WITHDIST] [WITHHASH]等参数后返回一个二层嵌套数组
具体返回值请查看后续示例,建议还是自己多搞几次就清楚了
代码示例:未给定任何 WITH 参数
给定[WITHCOORD] [WITHDIST] [WITHHASH]等参数,返回的时二层嵌套数组
2.5 GEORADIUSBYMEMBER
命令简介:
GEORADIUSBYMEMBER key member radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [ASC|DESC] [COUNT count]
GEORADIUSBYMEMBER 与 GEORADIUS 的区别在于,GEORADIUSBYMEMBER 无需给定经纬度,只需要给定成员的 key 就行,具体使用与 GEORADIUS 一致
代码示例:
2.6 GEOHASH
命令名称:
GEOHASH key member [member …]
返回一个或多个位置元素的 GeoHash 表示,可以给顶多个 key 中的 member,因此返回的是一个数组。
代码示例:
三、中国省会城市的经纬度
为了便于各位大佬们学习 Geospatial 的学习,我整理了全国省会城市的经纬度在这,有需要的可以自取。
(infoq 好像不能插入表格……)
版权声明: 本文为 InfoQ 作者【李子捌】的原创文章。
原文链接:【http://xie.infoq.cn/article/b1e8ecf76391e737e72875e27】。
本文遵守【CC-BY 4.0】协议,转载请保留原文出处及本版权声明。
评论