Redis地理数据类型GEO

2024-09-08 11:20
文章标签 数据类型 redis 地理 geo

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

 通常要计算两个地理位置的距离不是很方便,这里可以直接通过Redis提供的GEO操作来完成地理位置相关的计算

1)添加地理位置

语法:geoadd key longitude latitude member [longitude latitude member] ...
字段说明:
key:存放地理位置的集合名称
longitude:地理坐标的经度
latitude:地理坐标的纬度
member:表示这个地理位置的标识(可用地点名来代替)

添加一个 "天安门" 和 "北京西站" 的地理位置,如

geoadd China 116.397904 39.909005 天安门 116.322287 39.893729 北京西站

2)计算两个地理位置的距离

语法:geodist key member1 member2 [unit]
字段说明:
member:地理位置的标识
unit:距离单位(默认为米):m:米;km:千米;mi:英里;ft:英尺

计算 "天安门" 到 "北京西站" 的距离,如:

geodist China 天安门 北京西站 
或
geodist China 天安门 北京西站 m

3)获取地理位置的经纬度

语法:geopos key member ...
字段说明:
member:地理位置的标识

获取 "天安门" 的经纬度,如:

geopos China 天安门

4)获取地理位置的哈希值

语法:geohash key member ...
字段说明:
member:地理位置的标识

获取 "天安门的哈希值,如:

geohash China 天安门

5)搜索一定距离内圆形范围的地理位置

语法:

georadius key longitude latitude radius unit [withcoord] [withdist] [withhash] [count cnt] [asc.desc]

字段说明:
key:存放地理位置的集合名称
longitude:地理坐标的经度
latitude:地理坐标的纬度
radius:半径
unit:距离单位(默认为米):m:米;km:千米;mi:英里;ft:英尺
withcoord:可选参数,返回的结果中带上经纬度
withdist:可选参数,返回的结果中带上到达指定地理坐标的距离
withhash:可选参数,返回的结果中带上地理位置的哈希值
count:可选参数,查询地理位置个数的关键字,具体的数量放在cnt的位置,不指定count这个参数默认搜索所有满足距离的地理坐标
asc/desc:可选参数,asc,将搜索到的地理位置按照距离远近从小到大排序;desc,按照距离从大到小排序;不选择默认为asc

具体使用如下:

①  搜索 China地理集合 中所有距离(116.397904 39.909005)这个位置 10km 内的地理位置,默认返回的结果只有member,如:天安门 

georadius China 116.397904 39.909005 10 km ​ 

②  在 10km 范围内统计 100个 地理位置(包含member、经纬度、距离、哈希值),并将结果 从近到远 排序

georadius China 116.397904 39.909005 10 km withcoord withdist withhash count 100 asc 

6)以给定地点为中心,按照圆形或矩形搜索一定范围内的地理位置

语法:geosearch key [frommember member] / [fromlonlat longitude latitude] [byradius radius unit] / [bybox width height unit] [asc/desc] [count cnt] [withcoord] [withdist] [withhash]
字段说明:
key:存放地理位置的集合名称
frommember:按照member为中心,如按照天安门为中心;与fromlonlat二选一
member:地理位置的标识
fromlonlat:按照经纬度为中心;与frommember二选一
longitude:地理坐标的经度
latitude:地理坐标的纬度
byradius:按圆形搜索;与bybox二选一
radius:半径
bybox:按矩形搜索;与byradius二选一
width:矩形的宽
height:矩形的高
unit:距离单位(默认为米):m:米;km:千米;mi:英里;ft:英尺
asc/desc:可选参数,asc,将搜索到的地理位置按照距离远近从小到大排序;desc,按照距离从大到小排序;不选择 默认为asc
count:可选参数,查询地理位置个数的关键字,具体的数量放在cnt的位置,不指定count这个参数 默认搜索所有 满足距离的地理坐标
withcoord:可选参数,返回的结果中带上经纬度
withdist:可选参数,返回的结果中带上到达指定地理坐标的距离
withhash:可选参数,返回的结果中带上地理位置的哈希值

具体使用如下:

①  搜索 China 中距离 天安门 6km 所有位置

geosearch China frommember 天安门  byradius 6 km

②  以(116.397904 39.909005)经纬度为中心,在 宽500米,高1000米 的范围内统计 10个 地理位置(包含member、经纬度、距离、哈希值),并将结果 从近到远 排序

geosearch China fromlonlat 116.397904 39.909005 bybox 500 1000 m asc count 10  withcoord withdist withhash

这篇关于Redis地理数据类型GEO的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

三国地理揭秘:为何北伐之路如此艰难,为何诸葛亮无法攻克陇右小城?

俗话说:天时不如地利,不是随便说说,诸葛亮六出祁山,连关中陇右的几座小城都攻不下来,行军山高路险,无法携带和建造攻城器械,是最难的,所以在汉中,无论从哪一方进攻,防守方都是一夫当关,万夫莫开;再加上千里运粮,根本不需要打,司马懿只需要坚守城池拼消耗就能不战而屈人之兵。 另一边,洛阳的虎牢关,一旦突破,洛阳就无险可守,这样的进军路线,才是顺势而为的用兵之道。 读历史的时候我们常常看到某一方势

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

C 语言的基本数据类型

C 语言的基本数据类型 注:本文面向 C 语言初学者,如果你是熟手,那就不用看了。 有人问我,char、short、int、long、float、double 等这些关键字到底是什么意思,如果说他们是数据类型的话,那么为啥有这么多数据类型呢? 如果写了一句: int a; 那么执行的时候在内存中会有什么变化呢? 橡皮泥大家都玩过吧,一般你买橡皮泥的时候,店家会赠送一些模板。 上

Redis中使用布隆过滤器解决缓存穿透问题

一、缓存穿透(失效)问题 缓存穿透是指查询一个一定不存在的数据,由于缓存中没有命中,会去数据库中查询,而数据库中也没有该数据,并且每次查询都不会命中缓存,从而每次请求都直接打到了数据库上,这会给数据库带来巨大压力。 二、布隆过滤器原理 布隆过滤器(Bloom Filter)是一种空间效率很高的随机数据结构,它利用多个不同的哈希函数将一个元素映射到一个位数组中的多个位置,并将这些位置的值置

Lua 脚本在 Redis 中执行时的原子性以及与redis的事务的区别

在 Redis 中,Lua 脚本具有原子性是因为 Redis 保证在执行脚本时,脚本中的所有操作都会被当作一个不可分割的整体。具体来说,Redis 使用单线程的执行模型来处理命令,因此当 Lua 脚本在 Redis 中执行时,不会有其他命令打断脚本的执行过程。脚本中的所有操作都将连续执行,直到脚本执行完成后,Redis 才会继续处理其他客户端的请求。 Lua 脚本在 Redis 中原子性的原因

C语言程序设计(数据类型、运算符与表达式)

一、C的数据类型 C语言提供的数据类型: 二、常量和变量 2.1常量和符号常量 在程序运行过程中,其值不能被改变的量称为常量。 常量区分为不同的类型: 程序中用#define(预处理器指令)命令行定义变量将代表常量,用一个标识符代表一个常量,称为符合常量。 2.2变量 变量代表内存中具有特定属性的一个存储单元,用来存放数据,在程序运行期间,这些值是可以 改变的。 变

laravel框架实现redis分布式集群原理

在app/config/database.php中配置如下: 'redis' => array('cluster' => true,'default' => array('host' => '172.21.107.247','port' => 6379,),'redis1' => array('host' => '172.21.107.248','port' => 6379,),) 其中cl

Redis的rehash机制

在Redis中,键值对(Key-Value Pair)存储方式是由字典(Dict)保存的,而字典底层是通过哈希表来实现的。通过哈希表中的节点保存字典中的键值对。我们知道当HashMap中由于Hash冲突(负载因子)超过某个阈值时,出于链表性能的考虑,会进行Resize的操作。Redis也一样。 在redis的具体实现中,使用了一种叫做渐进式哈希(rehashing)的机制来提高字典的缩放效率,避

【吊打面试官系列-Redis面试题】说说 Redis 哈希槽的概念?

大家好,我是锋哥。今天分享关于 【说说 Redis 哈希槽的概念?】面试题,希望对大家有帮助; 说说 Redis 哈希槽的概念? Redis 集群没有使用一致性 hash,而是引入了哈希槽的概念,Redis 集群有 16384 个哈希槽,每个 key 通过 CRC16 校验后对 16384 取模来决定放置哪个槽, 集群的每个节点负责一部分 hash 槽。

Redis-主从集群

主从架构 单节点Redis的并发能力是有上限的,要进一步提高Redis的并发能力,就需要搭建主从集群,实现读写分离。 主从数据同步原理 全量同步 主从第一次建立连接时,会执行全量同步,将master节点的所有数据都拷贝给slave节点,流程: 判断是否是第一次同步,如果是,返回版本信息(replication id 和offset),将salve节点的版本信息变为master的