当前位置: 首页 > news >正文

redis-RedisTemplate.opsForGeo 的geo地理位置相关的方法演示

主要方法
add : 添加一个地理位置
distance: 计算两个元素之间的距离
hash: 获取元素经纬度坐标经过geohash算法生成的base32编码值
position: 获取集合中任意元素的经纬度坐标,可以一次获取多个
radius:查询某个坐标或某个成员,附近范围的成员

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.geo.*;
import org.springframework.data.redis.connection.RedisGeoCommands;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;@RestController
public class Controller_redis_geo_1 {@Autowiredprivate RedisTemplate redisTemplate;private final String KEY_GEO = "home";@RequestMapping("/testGeo")public void testGeo() {// geoadd : 添加一个地理位置// geoadd : (纬度、经度、名称)三元组redisTemplate.opsForGeo().add(KEY_GEO, new Point(116.48105, 39.996794), "张三");redisTemplate.opsForGeo().add(KEY_GEO, new Point(116.514203, 39.905409), "李四");redisTemplate.opsForGeo().add(KEY_GEO, new Point(116.489033, 40.007669), "王五");System.out.println();// geodist : 计算两个元素之间的距离// 计算张三李四之间的距离 其中,距离单位可以是m、km、ml、ft,分别代表米、千米、英里和尺Distance distance = redisTemplate.opsForGeo().distance(KEY_GEO, "张三", "李四");Distance distance2 = redisTemplate.opsForGeo().distance(KEY_GEO, "张三", "李四", RedisGeoCommands.DistanceUnit.KILOMETERS);System.out.println(distance);System.out.println(distance2.getValue());System.out.println();// geohash : 获取元素经纬度坐标经过geohash算法生成的base32编码值// 注意:GeoHash对二维经纬度坐标进行一维映射是有损的,通过映射再还原回的经纬度坐标和原始输入的经纬度坐标存在一定的误差。List<String> hash = redisTemplate.opsForGeo().hash(KEY_GEO, "张三");List<String> hashs = redisTemplate.opsForGeo().hash(KEY_GEO, "张三", "李四");System.out.println(hash);System.out.println(hashs);System.out.println();// geopos : 获取集合中任意元素的经纬度坐标,可以一次获取多个List<Point> position = redisTemplate.opsForGeo().position(KEY_GEO, "张三");System.out.println(position);List<Point> positions = redisTemplate.opsForGeo().position(KEY_GEO, "张三", "李四");System.out.println(positions);System.out.println();// GEORADIUS以给定的经纬度为中心, 返回键包含的位置元素当中, 与中心的距离不超过给定最大距离的所有位置元素。// 通过经度,纬度查找附近的人Circle circle = new Circle(116.48105, 39.996794, Metrics.KILOMETERS.getMultiplier());RedisGeoCommands.GeoRadiusCommandArgs args = RedisGeoCommands.GeoRadiusCommandArgs.newGeoRadiusArgs().includeDistance() //包含距离.includeCoordinates() //包含坐标.sortAscending() //升序.limit(50);GeoResults<RedisGeoCommands.GeoLocation<Object>> byxy = redisTemplate.opsForGeo().radius(KEY_GEO, circle, args);System.out.println("通过经纬度附近的人:");byxy.forEach(r -> System.out.println(r));System.out.println();// 通过地方查找附近5km的2个人RedisGeoCommands.GeoRadiusCommandArgs args2 = RedisGeoCommands.GeoRadiusCommandArgs.newGeoRadiusArgs().includeDistance().includeCoordinates().sortAscending().limit(2);GeoResults<RedisGeoCommands.GeoLocation<Object>> radius = redisTemplate.opsForGeo().radius(KEY_GEO, "张三", new Distance(5, Metrics.KILOMETERS), args2);System.out.println("通过名字附近的人:");radius.forEach(r -> System.out.println(r));}
}

http://www.lryc.cn/news/430098.html

相关文章:

  • 做短视频矩阵要十几人团队吗?云微客助阵,一人即可
  • 常用语音识别开源工具的对比与实践
  • Fortify代码安全测试工具在静态应用安全测试(SAST)方面针对典型问题的改进
  • AWS 消息队列服务 SQS
  • 【iOS】——响应者链和事件传递链
  • mysql查询慢
  • 【Java-==与equals】
  • ai回答 部署前端项目时需要使用ssh吗
  • 结合ChatGPT与Discord,提高团队合作效率
  • VisualStudio|开发环境相关技巧及问题
  • Redis远程字典服务器(11)—— redis客户端介绍
  • 【mysql】mysql之DDL数据定义语言
  • Word文件密码忘记,该如何才能编辑Word文件呢?
  • 解锁移动办公新境界,七款顶尖移动终端管控软件分享!助您轻松掌控每一台移动设备,企业必备!
  • 基于微信小程序的大用户心理咨询系统设计与实现---附源码99040
  • Bigtop 从0开始(上)
  • 算法基础及例题
  • 机器学习-KNN 算法
  • 【Linux】如何快速查看 linux 服务器有几个cpu
  • [数据集][目标检测]电力场景轭式悬架锈蚀分类数据集6351张2类别
  • 【嵌入式linux开发】智能家居入门5:老版ONENET,多协议接入(QT、微信小程序、HTTP协议、ONENET云平台、旭日x3派)
  • 软考-软件设计师(程序设计语言习题)
  • 「C++系列」vector 容器
  • 梯度的概念
  • 低代码开发:机遇与挑战并存的技术革新
  • Linux之RabbitMQ集群部署
  • 【JAVA CORE_API】Day19 多线程API(2)、多线程并发安全问题、同步
  • 最新Windows 11 23H2精简版,免费获取!稳定流畅!
  • PostgreSQL SELECT 语句:深入解析与实例应用
  • 【自然语言处理】 构建文本对话系统