redis之地理位置

2024-05-25 05:18
文章标签 redis 地理位置

本文主要是介绍redis之地理位置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

GEOADD

语法

返回值

GEOPOS

语法

返回值

GEODIST

语法

返回值

GEORADIUS

语法

返回值

GEOHASH

语法

返回值

GEORADIUSBYMEMBER

语法

返回值


 

官方文档:http://redisdoc.com/geo/georadiusbymember.html 

GEOADD

语法

GEOADD key longitude latitude member [longitude latitude member ...]

将给定的空间元素(经度,纬度,名字)添加到指定的键里面。

这些数据会以有序集合的形式被存储在键里面,从而使得像GEORADIUS和GEORADIUSBYMEMBER这样的命令可以在之后通过位置查询取得这些元素。

非常接近两级的区域是无法被索引的。

有效的经度介于-180°至180°之间

有效的纬度介于-85.05112878°至85.05112878°

当输入的范围超出经度或者纬度范围时,geoadd返回错误。

返回值

新添加到键里面的空间元素数量,不包括那些已经存在但是被更新的元素。

redis> GEOADD Sicily 13.361389 38.115556 "Palermo" 15.087269 37.502669 "Catania"
(integer) 2redis> GEODIST Sicily Palermo Catania
"166274.15156960039"redis> GEORADIUS Sicily 15 37 100 km
1) "Catania"redis> GEORADIUS Sicily 15 37 200 km
1) "Palermo"
2) "Catania"

GEOPOS

语法

GEOPOS key member [member ...]

从键里面返回所有给定位置元素的位置(经度和纬度)

因为geopos命令接受可变数量的位置元素作为参数,所以即使只给了一个位置元素,命令也会返回数组回复。

返回值

返回数组,数组中的每个项都由两个元素组成:第一个元素是给定位置元素的经度,第二个元素是给定元素的纬度。

当给定的位置不存在时,对应的数组为空值。

redis> GEOADD Sicily 13.361389 38.115556 "Palermo" 15.087269 37.502669 "Catania"
(integer) 2redis> GEOPOS Sicily Palermo Catania NonExisting
1) 1) "13.361389338970184"2) "38.115556395496299"
2) 1) "15.087267458438873"2) "37.50266842333162"
3) (nil)

GEODIST

语法

GEODIST key member1 member2 [unit]

返回两个给定位置之间的距离

如果两个位置之间的其中一个不存在,那么命令返回空值。

指定的单位unit必须是以下之一:

m:单位米
km:单位千米
mi:单位英里
ft:单位英尺

如果没有显示指定单位参数,那么默认为m。

GEODIST在计算距离时会假设地球为完美的球形,会造成0.5%的误差。

返回值

计算出的距离会以双精度浮点数的形式被返回,如果给定的位置不存在,那么命令返回空值。

redis> GEOADD Sicily 13.361389 38.115556 "Palermo" 15.087269 37.502669 "Catania"
(integer) 2redis> GEODIST Sicily Palermo Catania
"166274.15156960039"redis> GEODIST Sicily Palermo Catania km
"166.27415156960038"redis> GEODIST Sicily Palermo Catania mi
"103.31822459492736"redis> GEODIST Sicily Foo Bar
(nil)

GEORADIUS

语法

GEORADIUS key longitude latitude radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [ASC|DESC] [COUNT count]

以给定的经纬度为中心,返回键包含的位置元素当中,与中心的距离不超过给定最大距离的所有位置元素。

范围可以是以下其中一个单位

m:米
km:千米
mi:英里
ft:英尺

在给定以下可选项时,命令会返回额外的信息:

WITHSIST:在返回位置元素的同时,将位置元素与中心之间的距离也一并返回。距离的单位与用户给定的范围单位保持一致
WITHCOORD:将位置元素的经纬度一并返回
WITHHASH:以52位有符号整数的形式,返回位置元素经过原始geohash编码有序集合分值。主要用于底层应用或调试。

命令返回未排序的位置元素

ASC:根据中心位置,按照从近到远的方式返回位置元素
DESC:根据中心位置,按照从远到近的方式返回位置元素

默认情况下,GEORADIUS会返回所有匹配的位置元素。可以使用count<count>选项获取前N个匹配元素。但是命令内部可能会对所有匹配的元素进行处理,会导致命令执行速度很慢。但是使用count可以减少需要返回的元素数量,对于减少带宽是有用的。

返回值

返回一个数组。

在没有给定任何WITH选项情况下,返回一个像["new york", "paris"]这样的线性列表

指定了WITH选项的情况下,会返回一个二层嵌套数组。子数组的第一个元素总是位置元素的名字

GEOHASH

语法

GEOHASH key member [member …]

返回一个或多个位置元素的geohash表示

返回值

数组,数组的每个项都是一个geohash。返回的geohash的位置与用户给定的位置元素的位置一一对应。

GEORADIUSBYMEMBER

语法

GEORADIUSBYMEMBER key member radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [ASC|DESC] [COUNT count]

 

与georadius命令一样,可以找出位于指定范围内的元素,但是GEORADIUSBYMEMBER的中心点是由给定的位置元素决定的,而不是像georadius那样使用输入的经纬度来决定中心点。

返回值

数组,数组中的每个项表示一个范围内的位置元素

 

 

 

这篇关于redis之地理位置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1000578

相关文章

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

redis-sentinel基础概念及部署流程

《redis-sentinel基础概念及部署流程》RedisSentinel是Redis的高可用解决方案,通过监控主从节点、自动故障转移、通知机制及配置提供,实现集群故障恢复与服务持续可用,核心组件包... 目录一. 引言二. 核心功能三. 核心组件四. 故障转移流程五. 服务部署六. sentinel部署

基于Redis自动过期的流处理暂停机制

《基于Redis自动过期的流处理暂停机制》基于Redis自动过期的流处理暂停机制是一种高效、可靠且易于实现的解决方案,防止延时过大的数据影响实时处理自动恢复处理,以避免积压的数据影响实时性,下面就来详... 目录核心思路代码实现1. 初始化Redis连接和键前缀2. 接收数据时检查暂停状态3. 检测到延时过

Redis实现分布式锁全过程

《Redis实现分布式锁全过程》文章介绍Redis实现分布式锁的方法,包括使用SETNX和EXPIRE命令确保互斥性与防死锁,Redisson客户端提供的便捷接口,以及Redlock算法通过多节点共识... 目录Redis实现分布式锁1. 分布式锁的基本原理2. 使用 Redis 实现分布式锁2.1 获取锁

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

redis数据结构之String详解

《redis数据结构之String详解》Redis以String为基础类型,因C字符串效率低、非二进制安全等问题,采用SDS动态字符串实现高效存储,通过RedisObject封装,支持多种编码方式(如... 目录一、为什么Redis选String作为基础类型?二、SDS底层数据结构三、RedisObject

Redis分布式锁中Redission底层实现方式

《Redis分布式锁中Redission底层实现方式》Redission基于Redis原子操作和Lua脚本实现分布式锁,通过SETNX命令、看门狗续期、可重入机制及异常处理,确保锁的可靠性和一致性,是... 目录Redis分布式锁中Redission底层实现一、Redission分布式锁的基本使用二、Red

redis和redission分布式锁原理及区别说明

《redis和redission分布式锁原理及区别说明》文章对比了synchronized、乐观锁、Redis分布式锁及Redission锁的原理与区别,指出在集群环境下synchronized失效,... 目录Redis和redission分布式锁原理及区别1、有的同伴想到了synchronized关键字