【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 的地理位置类型,存储和查询地理位置信息。在实际应用中,地理位置类型可以用于实现附近的人、周边搜索等功能。

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

相关推荐
秋意钟1 小时前
缓存雪崩、缓存穿透【Redis】
redis
简 洁 冬冬1 小时前
046 购物车
redis·购物车
soulteary2 小时前
突破内存限制:Mac Mini M2 服务器化实践指南
运维·服务器·redis·macos·arm·pika
wkj0013 小时前
php操作redis
开发语言·redis·php
菠萝咕噜肉i3 小时前
超详细:Redis分布式锁
数据库·redis·分布式·缓存·分布式锁
登云时刻5 小时前
Kubernetes集群外连接redis集群和使用redis-shake工具迁移数据(二)
redis·容器·kubernetes
Dlwyz8 小时前
redis-击穿、穿透、雪崩
数据库·redis·缓存
工业甲酰苯胺10 小时前
Redis性能优化的18招
数据库·redis·性能优化
Oak Zhang12 小时前
sharding-jdbc自定义分片算法,表对应关系存储在mysql中,缓存到redis或者本地
redis·mysql·缓存
门牙咬脆骨13 小时前
【Redis】redis缓存击穿,缓存雪崩,缓存穿透
数据库·redis·缓存