redis的GEO实战 (RedisTemplate)

本文详细介绍了RedisTemplate在GEO操作中的使用,包括geoadd、geopos、geodist、georadius、georadiusbymember和geohash等命令,以及RedisTemplate的API封装,提供了一种在Java中方便地处理地理位置信息的方法。
摘要由CSDN通过智能技术生成

相关命令

geoadd

时间复杂度为O(log(N))

geoadd cityGeo 116.405285 39.904989 "北京"
geoadd cityGeo 121.472644 31.231706 "上海"
  • 添加经纬度信息

geopos

时间复杂度为O(log(N))

127.0.0.1:6379> geopos cityGeo 北京
1) 1) "116.40528291463851929"
   2) "39.9049884229125027"
  • 查找指定key的经纬度信息,可以指定多个key,批量返回

geodist

时间复杂度为O(log(N))

127.0.0.1:6379> geodist cityGeo 北京 上海
"1067597.9668"
127.0.0.1:6379> geodist cityGeo 北京 上海 km
"1067.5980"
  • 返回两个地方的距离,可以指定单位,比如米m,千米km,英里mi,英尺ft

georadius

时间复杂度为O(N+log(M)),N为指定半径范围内的元素个数,M为要返回的个数

georadius cityGeo 116.405285 39.904989 100 km WITHDIST WITHCOORD ASC COUNT 5
  • 根据给定的经纬度,返回半径不超过指定距离的元素
  • 可以指定WITHDIST返回距离,WITHCOORD返回经纬度,WITHHASH返回geohash值
  • 可以指定ASC或DESC,根据距离来排序
  • 可以指定COUNT限定返回的记录数

georadiusbymember

时间复杂度为O(log(N)+M),N为指定半径范围内的元素个数,M为要返回的个数

georadiusbymember cityGeo 北京 100 km WITHDIST WITHCOORD ASC COUNT 5
  • 根据指定的地点查询半径在指定范围内的位置
  • 可以指定WITHDIST返回距离,WITHCOORD返回经纬度,WITHHASH返回geohash值
  • 可以指定ASC或DESC,根据距离来排序
  • 可以指定COUNT限定返回的记录数

geohash

查找一个位置的时间复杂度为O(log(N))

127.0.0.1:6379> geohash ci
RedisTemplate是Spring Data Redis提供的一个Redis客户端操作工具类,封装了Redis的基本操作方法,支持多种数据类型的操作,包括字符串、哈希、列表、集合、有序集合等。 RedisGEO命令是用来处理地理位置数据的命令,可以实现以下功能: - 将给定的地理空间位置(经度、纬度、名称)添加到指定的key中。 - 获取指定地理位置的经度和纬度。 - 获取两个地理位置之间的距离。 - 根据用户给定的地理位置坐标获取指定范围内的地理位置集合。 - 获取指定地理位置周围的地理位置集合。 下面是一个基于RedisTemplateRedis GEO工具类的示例: ```java @Component public class RedisGeoUtil { @Autowired private RedisTemplate<String, Object> redisTemplate; /** * 将给定的地理空间位置(经度、纬度、名称)添加到指定的key中 * @param key 键名 * @param longitude 经度 * @param latitude 纬度 * @param member 成员名称 * @return 添加的成员数量 */ public Long geoAdd(String key, double longitude, double latitude, Object member) { Point point = new Point(longitude, latitude); return redisTemplate.opsForGeo().add(key, point, member); } /** * 获取指定地理位置的经度和纬度 * @param key 键名 * @param member 成员名称 * @return 经纬度信息 */ public Point geoGet(String key, Object member) { return redisTemplate.opsForGeo().position(key, member); } /** * 获取两个地理位置之间的距离 * @param key 键名 * @param member1 成员1名称 * @param member2 成员2名称 * @param metric 单位(默认为米,也可以是千米、英里等) * @return 两个地理位置之间的距离 */ public Distance geoDistance(String key, Object member1, Object member2, Metric metric) { return redisTemplate.opsForGeo().distance(key, member1, member2, metric); } /** * 根据用户给定的地理位置坐标获取指定范围内的地理位置集合 * @param key 键名 * @param longitude 经度 * @param latitude 纬度 * @param radius 范围 * @param unit 单位 * @return 附近的成员列表 */ public GeoResults<RedisGeoCommands.GeoLocation<Object>> geoRadius(String key, double longitude, double latitude, double radius, RedisGeoCommands.DistanceUnit unit) { Point point = new Point(longitude, latitude); Circle circle = new Circle(point, new Distance(radius, unit)); RedisGeoCommands.GeoRadiusCommandArgs args = RedisGeoCommands.GeoRadiusCommandArgs .newGeoRadiusArgs().includeDistance().includeCoordinates().sortAscending(); return redisTemplate.opsForGeo().radius(key, circle, args); } /** * 获取指定地理位置周围的地理位置集合 * @param key 键名 * @param member 成员名称 * @param radius 范围 * @param unit 单位 * @return 附近的成员列表 */ public GeoResults<RedisGeoCommands.GeoLocation<Object>> geoNearByMember(String key, Object member, double radius, RedisGeoCommands.DistanceUnit unit) { RedisGeoCommands.GeoRadiusCommandArgs args = RedisGeoCommands.GeoRadiusCommandArgs .newGeoRadiusArgs().includeDistance().includeCoordinates().sortAscending(); return redisTemplate.opsForGeo().radius(key, member, new Distance(radius, unit), args); } } ``` 上述工具类中的方法分别对应了Redis GEO命令中的各个功能,使用起来非常方便。需要注意的是,在使用Redis GEO命令时,需要Redis版本2.8.9以上的支持。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值