【Redis GEO】1、地理位置类型的基本用法

1、Redis GEO介绍

Redis GEO 主要用于存储地理位置信息,并对存储的信息进行操作,该功能在 Redis 3.2 版本新增。

Redis GEO 操作方法有:

  • geoadd:添加地理位置的坐标。
  • geopos:获取地理位置的坐标。
  • geodist:计算两个位置之间的距离。
  • georadius:根据用户给定的经纬度坐标来获取指定范围内的地理位置集合。
  • georadiusbymember:根据储存在位置集合里面的某个地点获取指定范围内的地理位置集合。
  • geohash:返回一个或多个位置对象的 geohash 值。

2、geoadd

geoadd 用于存储指定的地理空间位置,可以将一个或多个经度(longitude)、纬度(latitude)、位置名称(member)添加到指定的 key 中。geoadd 语法格式如下:

java 复制代码
GEOADD key longitude latitude member [longitude latitude member ...]

其中,key 是键名,longitude 和 latitude 是地理位置的经度和纬度,member 是地理位置的成员名,例如:

java 复制代码
GEOADD citys 121.506379 31.245414 "东方明珠广播电视塔"

上述命令将【东方明珠广播电视塔】的经度为 121.506379,纬度为 31.245414 的地理位置添加到了名为【citys】的键中,并将其成员名设置为 "东方明珠广播电视塔"

3、geopos

geopos 用于从给定的 key 里返回所有指定名称(member)的位置(经度和纬度),不存在的返回 nil。geopos 语法格式如下:

java 复制代码
GEOPOS key member [member ...]

其中,key 是键名,member 是地理位置的成员名

例如,上面我们已经添加了 【东方明珠广播电视塔】的地理位置信息,我们可以使用以下命令获取其经度和纬度:

java 复制代码
GEOPOS citys "东方明珠广播电视塔"

上述命令将返回【东方明珠广播电视塔】的经度和纬度,例如:[121.506379,31.245414]

4、geodist

geodist 用于返回两个给定位置之间的距离。geodist 语法格式如下:

java 复制代码
GEODIST key member1 member2 [m|km|ft|mi]

其中,key 是键名,member1 和 member2 是地理位置的成员名,最后一个参数是距离的单位,默认为 "m"(米)。最后一个距离单位参数说明:

  • m :米,默认单位。
  • km :千米。
  • mi :英里。
  • ft :英尺。

例如,上面我们已经添加了 【东方明珠广播电视塔】的地理位置信息,我们再添加一个地理位置信息:

java 复制代码
GEOADD citys 121.671964 31.148267 "上海迪士尼度假区"

然后,获取两个地理位置的距离:

java 复制代码
GEODIST citys "东方明珠广播电视塔" "上海迪士尼度假区"

上述命令将返回【东方明珠广播电视塔】和【上海迪士尼度假区】之间的距离,单位为米。

5、总结

本文介绍了 Redis 的地理位置类型(Geo),以及与之相关的命令,包括 GEOADD、GEOPOS、GEODIST 和 INFO。通过 redis-cli 命令行工具,我们可以方便地操作 Redis 的地理位置类型,存储和查询地理位置信息。在实际应用中,地理位置类型可以用于实现附近的人、周边搜索等功能。

如您在阅读中发现不足,欢迎留言!!!

相关推荐
纪元A梦1 天前
Redis最佳实践——安全与稳定性保障之高可用架构详解
redis·安全·架构
无敌的神原秋人1 天前
关于Redis不同序列化压缩性能的对比
java·redis·缓存
恣艺2 天前
Redis列表(List):实现队列/栈的利器,底层原理与实战
数据库·redis·list
论迹2 天前
【Redis】-- 持久化
数据库·redis·缓存
getdu2 天前
Redis面试相关
数据库·redis·面试
belldeep2 天前
Win10 上 Debian 12 如何安装 Redis ?
运维·redis·debian
孙同学_2 天前
【C++】AVL树
c++·redis
island13142 天前
【Redis#9】其他数据结构
数据结构·数据库·redis
winfield8212 天前
Redis 线上问题排查完整手册
redis
七夜zippoe2 天前
多级缓存架构实战手册:Caffeine+Redis 从设计到落地的全链路解决方案
redis·缓存·架构