1. 序列化和配置
package com.xxx.redis;
import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.jsontype.impl.LaissezFaireSubTypeValidator;
import com.xxx.redis.service.RedisService;
import com.xxx.redis.service.impl.DefaultRedisServiceImpl;
import org.springframework.boot.autoconfigure.data.redis.RedisAutoConfiguration;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializer;
/**
* RedisConfiguration
*
* @author xm.z
*/
@Configuration
public class RedisConfiguration {
@Bean
public RedisSerializer redisSerializer() {
// 创建 JSON 序列化器
Jackson2JsonRedisSerializer serializer = new Jackson2JsonRedisSerializer<>(Object.class);
ObjectMapper objectMapper = new ObjectMapper();
objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
// 必须设置 否则无法将JSON转化为对象 会转化成Map类型
objectMapper.activateDefaultTyping(LaissezFaireSubTypeValidator.instance, ObjectMapper.DefaultTyping.NON_FINAL);
serializer.setObjectMapper(objectMapper);
return serializer;
}
@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory,
RedisSerializer redisSerializer) {
RedisTemplate redisTemplate = new RedisTemplate<>();
redisTemplate.setConnectionFactory(redisConnectionFactory);
redisTemplate.setKeySerializer(RedisSerializer.string());
redisTemplate.setValueSerializer(redisSerializer);
redisTemplate.setHashKeySerializer(RedisSerializer.string());
redisTemplate.setHashValueSerializer(redisSerializer);
redisTemplate.afterPropertiesSet();
return redisTemplate;
}
@Bean
public RedisService redisService(RedisTemplate redisTemplate) {
return new DefaultRedisServiceImpl(redisTemplate);
}
}
2. 基础常量
package com.xxx.redis.constant;
import org.springframework.data.redis.core.script.DefaultRedisScript;
/**
* RedisConstants
*
* @author xm.z
*/
public final class RedisConstants {
/**
* 递增并设置过期时间的 lua 脚本
*/
public static final DefaultRedisScript INCR_BY_EXPIRE_LUA_SCRIPT = new DefaultRedisScript<>(
"local r = redis.call('INCRBY', KEYS[1], ARGV[1]) redis.call('EXPIRE', KEYS[1], ARGV[2]) return r",
Long.class);
/**
* 递减并设置过期时间的 lua 脚本
*/
public static final DefaultRedisScript DECR_BY_EXPIRE_LUA_SCRIPT = new DefaultRedisScript<>(
"local r = redis.call('DECRBY', KEYS[1], ARGV[1]) redis.call('EXPIRE', KEYS[1], ARGV[2]) return r",
Long.class);
private RedisConstants() {
}
}
3. 接口及实现
package com.xxx.redis.service.impl;
import com.xxx.redis.service.RedisService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.data.redis.core.*;
/**
* AbstractRedisService
*
* @author xm.z
*/
@Slf4j
public abstract class AbstractRedisService implements RedisService {
/**
* Get Helper class that simplifies Redis data access code.
* @return RedisTemplate 获取
*/
protected abstract RedisTemplate getTemplate();
public HashOperations hashOps() {
return this.getTemplate().opsForHash();
}
public ValueOperations valueOps() {
return this.getTemplate().opsForValue();
}
public ListOperations listOps() {
return this.getTemplate().opsForList();
}
public SetOperations setOps() {
return this.getTemplate().opsForSet();
}
public ZSetOperations zSetOps() {
return this.getTemplate().opsForZSet();
}
public StreamOperations streamOps() {
return this.getTemplate().opsForStream();
}
public GeoOperations geoOps() {
return this.getTemplate().opsForGeo();
}
}
package com.xxx.redis.service;
import org.springframework.data.domain.Sort;
import org.springframework.data.geo.Distance;
import org.springframework.data.geo.GeoResults;
import org.springframework.data.geo.Point;
import org.springframework.data.redis.connection.RedisGeoCommands;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.Set;
/**
* Redis 服务
*
* @author xm.z
*/
public interface RedisService {
/**
* 获取所有符合指定表达式的 key
* @param pattern 表达式
* @return java.util.Set
* @see Keys Command
*/
Set keys(String pattern);
/**
* 保存属性
* @param key key值
* @param value value值
* @param time 时间戳
*/
void set(String key, Object value, long time);
/**
* 保存属性
* @param key key值
* @param value value值
*/
void set(String key, Object value);
/**
* 获取属性
* @param key key值
* @return 返回对象
*/
Object get(String key);
/**
* 从指定的 keys 批量获取属性
* @param keys keys
* @return values list,当值为空时,该 key 对应的 value 为 null
* @see MGet Command
*/
List mGet(Collection keys);
/**
* 批量获取 keys 的属性,并返回一个 map
* @param keys keys
* @return map,key 和 value 的键值对集合,当 value 获取为 null 时,不存入此 map
*/
Map mGetToMap(Collection keys);
/**
* 删除属性
* @param key key值
* @return 返回成功
*/
Boolean del(String key);
/**
* 批量删除属性
* @param keys key值集合
* @return 返回删除数量
*/
Long del(Collection keys);
/**
* 设置过期时间
* @param key key值
* @param time 时间戳
* @return 返回成功
*/
Boolean expire(String key, long time);
/**
* 获取过期时间
* @param key key值
* @return 返回时间戳
*/
Long getExpire(String key);
/**
* 判断key是否存在
* @param key key值
* @return 返回
*/
Boolean hasKey(String key);
/**
* 按delta递增
* @param key key值
* @param delta delta值
* @return 返回递增后结果
*/
Long incr(String key, long delta);
/**
* 按delta递增并设置过期时间
* @param key key值
* @param delta delta值
* @param timeout 过期时间(单位:秒)
* @return 返回递增后结果
*/
Long incrAndExpire(String key, long delta, long timeout);
/**
* 按delta递减
* @param key key值
* @param delta delta值
* @return 返回递减后结果
*/
Long decr(String key, long delta);
/**
* 按delta递减并设置过期时间
* @param key key值
* @param delta delta值
* @param timeout 过期时间(单位:秒)
* @return 返回递减后结果
*/
Long decrAndExpire(String key, long delta, long timeout);
/**
* 获取Hash结构中的属性
* @param key 外部key值
* @param hashKey 内部key值
* @return 返回内部key的value
*/
Object hGet(String key, String hashKey);
/**
* 向Hash结构中放入一个属性
* @param key 外部key
* @param hashKey 内部key
* @param value 内部key的value
* @param time 过期时间
* @return 返回是否成功
*/
Boolean hSet(String key, String hashKey, Object value, long time);
/**
* 向Hash结构中放入一个属性
* @param key 外部key
* @param hashKey 内部key
* @param value 内部key的value
*/
void hSet(String key, String hashKey, Object value);
/**
* 直接获取整个Hash结构
* @param key 外部key值
* @return 返回hashMap
*/
Map hGetAll(String key);
/**
* 直接设置整个Hash结构
* @param key 外部key
* @param map hashMap值
* @param time 过期时间
* @return 返回是否成功
*/
Boolean hSetAll(String key, Map map, long time);
/**
* 直接设置整个Hash结构
* @param key 外部key
* @param map hashMap值
*/
void hSetAll(String key, Map map);
/**
* 删除Hash结构中的属性
* @param key 外部key值
* @param hashKey 内部key值
*/
void hDel(String key, Object... hashKey);
/**
* 判断Hash结构中是否有该属性
* @param key 外部key
* @param hashKey 内部key
* @return 返回是否存在
*/
Boolean hHasKey(String key, String hashKey);
/**
* Hash结构中属性递增
* @param key 外部key
* @param hashKey 内部key
* @param delta 递增条件
* @return 返回递增后的数据
*/
Long hIncr(String key, String hashKey, Long delta);
/**
* Hash结构中属性递减
* @param key 外部key
* @param hashKey 内部key
* @param delta 递增条件
* @return 返回递减后的数据
*/
Long hDecr(String key, String hashKey, Long delta);
/**
* 获取Set结构
* @param key key
* @return 返回set集合
*/
Set sMembers(String key);
/**
* 向Set结构中添加属性
* @param key key
* @param values value集
* @return 返回增加数量
*/
Long sAdd(String key, Object... values);
/**
* 向Set结构中添加属性
* @param key key
* @param time 过期时间
* @param values 值集合
* @return 返回添加的数量
*/
Long sAdd(String key, long time, Object... values);
/**
* 是否为Set中的属性
* @param key key
* @param value value
* @return 返回是否存在
*/
Boolean sIsMember(String key, Object value);
/**
* 获取Set结构的长度
* @param key key
* @return 返回长度
*/
Long sSize(String key);
/**
* 删除Set结构中的属性
* @param key key
* @param values value集合
* @return 删除掉的数据量
*/
Long sRemove(String key, Object... values);
/**
* 获取List结构中的属性
* @param key key
* @param start 开始
* @param end 结束
* @return 返回查询的集合
*/
List lRange(String key, long start, long end);
/**
* 获取List结构的长度
* @param key key
* @return 长度
*/
Long lSize(String key);
/**
* 根据索引获取List中的属性
* @param key key
* @param index 索引
* @return 对象
*/
Object lIndex(String key, long index);
/**
* 向List结构中添加属性
* @param key key
* @param value value
* @return 增加后的长度
*/
Long lPush(String key, Object value);
/**
* 向List结构中添加属性
* @param key key
* @param value value
* @param time 过期时间
* @return 增加后的长度
*/
Long lPush(String key, Object value, long time);
/**
* 向List结构中批量添加属性
* @param key key
* @param values value 集合
* @return 增加后的长度
*/
Long lPushAll(String key, Object... values);
/**
* 向List结构中批量添加属性
* @param key key
* @param time 过期时间
* @param values value集合
* @return 增加后的长度
*/
Long lPushAll(String key, Long time, Object... values);
/**
* 从List结构中移除属性
* @param key key
* @param count 总量
* @param value value
* @return 返回删除后的长度
*/
Long lRemove(String key, long count, Object value);
/**
* 向bitmap中新增值
* @param key key
* @param offset 偏移量
* @param b 状态
* @return 结果
*/
Boolean bitAdd(String key, int offset, boolean b);
/**
* 从bitmap中获取偏移量的值
* @param key key
* @param offset 偏移量
* @return 结果
*/
Boolean bitGet(String key, int offset);
/**
* 获取bitmap的key值总和
* @param key key
* @return 总和
*/
Long bitCount(String key);
/**
* 获取bitmap范围值
* @param key key
* @param limit 范围
* @param offset 开始偏移量
* @return long类型集合
*/
List bitField(String key, int limit, int offset);
/**
* 获取所有bitmap
* @param key key
* @return 以二进制字节数组返回
*/
byte[] bitGetAll(String key);
/**
* 增加坐标
* @param key key
* @param x x
* @param y y
* @param name 地点名称
* @return 返回结果
*/
Long geoAdd(String key, Double x, Double y, String name);
/**
* 根据城市名称获取坐标集合
* @param key key
* @param place 地点
* @return 坐标集合
*/
List geoGetPointList(String key, Object... place);
/**
* 计算两个城市之间的距离
* @param key key
* @param placeOne 地点1
* @param placeTow 地点2
* @return 返回距离
*/
Distance geoCalculationDistance(String key, String placeOne, String placeTow);
/**
* 获取附该地点附近的其他地点
* @param key key
* @param place 地点
* @param distance 附近的范围
* @param limit 查几条
* @param sort 排序规则
* @return 返回附近的地点集合
*/
GeoResults> geoNearByPlace(String key, String place, Distance distance,
long limit, Sort.Direction sort);
/**
* 获取地点的hash
* @param key key
* @param place 地点
* @return 返回集合
*/
List geoGetHash(String key, String... place);
}
package com.xxx.redis.service.impl;
import lombok.RequiredArgsConstructor;
import org.springframework.data.domain.Sort;
import org.springframework.data.geo.Distance;
import org.springframework.data.geo.GeoResults;
import org.springframework.data.geo.Point;
import org.springframework.data.redis.connection.BitFieldSubCommands;
import org.springframework.data.redis.connection.RedisGeoCommands;
import org.springframework.data.redis.core.RedisCallback;
import org.springframework.data.redis.core.RedisTemplate;
import java.util.*;
import java.util.concurrent.TimeUnit;
import static com.xxx.redis.constant.RedisConstants.DECR_BY_EXPIRE_LUA_SCRIPT;
import static com.xxx.redis.constant.RedisConstants.INCR_BY_EXPIRE_LUA_SCRIPT;
/**
* 默认 Redis 服务实现
*
* @author xm.z
*/
@RequiredArgsConstructor
public class DefaultRedisServiceImpl extends AbstractRedisService {
private final RedisTemplate redisTemplate;
/**
* 获取所有符合指定表达式的 key
* @param pattern 表达式
* @return java.util.Set
* @see Keys Command
*/
@Override
public Set keys(String pattern) {
return redisTemplate.keys(pattern);
}
/**
* 保存属性
* @param key key值
* @param value value值
* @param time 时间戳
*/
@Override
public void set(String key, Object value, long time) {
valueOps().set(key, value, time, TimeUnit.SECONDS);
}
/**
* 保存属性
* @param key key值
* @param value value值
*/
@Override
public void set(String key, Object value) {
valueOps().set(key, value);
}
/**
* 获取属性
* @param key key值
* @return 返回对象
*/
@Override
public Object get(String key) {
return valueOps().get(key);
}
/**
* 从指定的 keys 批量获取属性
* @param keys keys
* @return values list,当值为空时,该 key 对应的 value 为 null
* @see MGet Command
*/
@Override
public List mGet(Collection keys) {
return valueOps().multiGet(keys);
}
/**
* 批量获取 keys 的属性,并返回一个 map
* @param keys keys
* @return map,key 和 value 的键值对集合,当 value 获取为 null 时,不存入此 map
*/
@Override
public Map mGetToMap(Collection keys) {
List values = valueOps().multiGet(keys);
Map map = new HashMap<>(keys.size());
if (values == null || values.isEmpty()) {
return map;
}
Iterator keysIterator = keys.iterator();
Iterator valuesIterator = values.iterator();
while (keysIterator.hasNext()) {
String key = keysIterator.next();
Object value = valuesIterator.next();
if (value != null) {
map.put(key, value);
}
}
return map;
}
/**
* 删除属性
* @param key key值
* @return 返回成功
*/
@Override
public Boolean del(String key) {
return redisTemplate.delete(key);
}
/**
* 批量删除属性
* @param keys key值集合
* @return 返回删除数量
*/
@Override
public Long del(Collection keys) {
return redisTemplate.delete(keys);
}
/**
* 设置过期时间
* @param key key值
* @param time 时间戳
* @return 返回成功
*/
@Override
public Boolean expire(String key, long time) {
return redisTemplate.expire(key, time, TimeUnit.SECONDS);
}
/**
* 获取过期时间
* @param key key值
* @return 返回时间戳
*/
@Override
public Long getExpire(String key) {
return redisTemplate.getExpire(key, TimeUnit.SECONDS);
}
/**
* 判断key是否存在
* @param key key值
* @return 返回
*/
@Override
public Boolean hasKey(String key) {
return redisTemplate.hasKey(key);
}
/**
* 按delta递增
* @param key key值
* @param delta delta值
* @return 返回递增后结果
*/
@Override
public Long incr(String key, long delta) {
return valueOps().increment(key, delta);
}
/**
* 按delta递增并设置过期时间
* @param key key值
* @param delta delta值
* @param timeout 过期时间(单位:秒)
* @return 返回递增后结果
*/
@Override
public Long incrAndExpire(String key, long delta, long timeout) {
return redisTemplate.execute(INCR_BY_EXPIRE_LUA_SCRIPT, Collections.singletonList(key), String.valueOf(delta),
String.valueOf(timeout));
}
/**
* 按delta递减
* @param key key值
* @param delta delta值
* @return 返回递减后结果
*/
@Override
public Long decr(String key, long delta) {
return valueOps().decrement(key, delta);
}
/**
* 按delta递减并设置过期时间
* @param key key值
* @param delta delta值
* @param timeout 过期时间(单位:秒)
* @return 返回递减后结果
*/
@Override
public Long decrAndExpire(String key, long delta, long timeout) {
return redisTemplate.execute(DECR_BY_EXPIRE_LUA_SCRIPT, Collections.singletonList(key), String.valueOf(delta),
String.valueOf(timeout));
}
/**
* 获取Hash结构中的属性
* @param key 外部key值
* @param hashKey 内部key值
* @return 返回内部key的value
*/
@Override
public Object hGet(String key, String hashKey) {
return hashOps().get(key, hashKey);
}
/**
* 向Hash结构中放入一个属性
* @param key 外部key
* @param hashKey 内部key
* @param value 内部key的value
* @param time 过期时间
* @return 返回是否成功
*/
@Override
public Boolean hSet(String key, String hashKey, Object value, long time) {
hashOps().put(key, hashKey, value);
return expire(key, time);
}
/**
* 向Hash结构中放入一个属性
* @param key 外部key
* @param hashKey 内部key
* @param value 内部key的value
*/
@Override
public void hSet(String key, String hashKey, Object value) {
hashOps().put(key, hashKey, value);
}
/**
* 直接获取整个Hash结构
* @param key 外部key值
* @return 返回hashMap
*/
@Override
public Map hGetAll(String key) {
return hashOps().entries(key);
}
/**
* 直接设置整个Hash结构
* @param key 外部key
* @param map hashMap值
* @param time 过期时间
* @return 返回是否成功
*/
@Override
public Boolean hSetAll(String key, Map map, long time) {
hashOps().putAll(key, map);
return expire(key, time);
}
/**
* 直接设置整个Hash结构
* @param key 外部key
* @param map hashMap值
*/
@Override
public void hSetAll(String key, Map map) {
hashOps().putAll(key, map);
}
/**
* 删除Hash结构中的属性
* @param key 外部key值
* @param hashKey 内部key值
*/
@Override
public void hDel(String key, Object... hashKey) {
hashOps().delete(key, hashKey);
}
/**
* 判断Hash结构中是否有该属性
* @param key 外部key
* @param hashKey 内部key
* @return 返回是否存在
*/
@Override
public Boolean hHasKey(String key, String hashKey) {
return hashOps().hasKey(key, hashKey);
}
/**
* Hash结构中属性递增
* @param key 外部key
* @param hashKey 内部key
* @param delta 递增条件
* @return 返回递增后的数据
*/
@Override
public Long hIncr(String key, String hashKey, Long delta) {
return hashOps().increment(key, hashKey, delta);
}
/**
* Hash结构中属性递减
* @param key 外部key
* @param hashKey 内部key
* @param delta 递增条件
* @return 返回递减后的数据
*/
@Override
public Long hDecr(String key, String hashKey, Long delta) {
return hashOps().increment(key, hashKey, -delta);
}
/**
* 获取Set结构
* @param key key
* @return 返回set集合
*/
@Override
public Set sMembers(String key) {
return setOps().members(key);
}
/**
* 向Set结构中添加属性
* @param key key
* @param values value集
* @return 返回增加数量
*/
@Override
public Long sAdd(String key, Object... values) {
return setOps().add(key, values);
}
/**
* 向Set结构中添加属性
* @param key key
* @param time 过期时间
* @param values 值集合
* @return 返回添加的数量
*/
@Override
public Long sAdd(String key, long time, Object... values) {
Long count = setOps().add(key, values);
expire(key, time);
return count;
}
/**
* 是否为Set中的属性
* @param key key
* @param value value
* @return 返回是否存在
*/
@Override
public Boolean sIsMember(String key, Object value) {
return setOps().isMember(key, value);
}
/**
* 获取Set结构的长度
* @param key key
* @return 返回长度
*/
@Override
public Long sSize(String key) {
return setOps().size(key);
}
/**
* 删除Set结构中的属性
* @param key key
* @param values value集合
* @return 删除掉的数据量
*/
@Override
public Long sRemove(String key, Object... values) {
return setOps().remove(key, values);
}
/**
* 获取List结构中的属性
* @param key key
* @param start 开始
* @param end 结束
* @return 返回查询的集合
*/
@Override
public List lRange(String key, long start, long end) {
return listOps().range(key, start, end);
}
/**
* 获取List结构的长度
* @param key key
* @return 长度
*/
@Override
public Long lSize(String key) {
return listOps().size(key);
}
/**
* 根据索引获取List中的属性
* @param key key
* @param index 索引
* @return 对象
*/
@Override
public Object lIndex(String key, long index) {
return listOps().index(key, index);
}
/**
* 向List结构中添加属性
* @param key key
* @param value value
* @return 增加后的长度
*/
@Override
public Long lPush(String key, Object value) {
return listOps().rightPush(key, value);
}
/**
* 向List结构中添加属性
* @param key key
* @param value value
* @param time 过期时间
* @return 增加后的长度
*/
@Override
public Long lPush(String key, Object value, long time) {
Long index = listOps().rightPush(key, value);
expire(key, time);
return index;
}
/**
* 向List结构中批量添加属性
* @param key key
* @param values value 集合
* @return 增加后的长度
*/
@Override
public Long lPushAll(String key, Object... values) {
return listOps().rightPushAll(key, values);
}
/**
* 向List结构中批量添加属性
* @param key key
* @param time 过期时间
* @param values value集合
* @return 增加后的长度
*/
@Override
public Long lPushAll(String key, Long time, Object... values) {
Long count = listOps().rightPushAll(key, values);
expire(key, time);
return count;
}
/**
* 从List结构中移除属性
* @param key key
* @param count 总量
* @param value value
* @return 返回删除后的长度
*/
@Override
public Long lRemove(String key, long count, Object value) {
return listOps().remove(key, count, value);
}
/**
* 向bitmap中新增值
* @param key key
* @param offset 偏移量
* @param b 状态
* @return 结果
*/
@Override
public Boolean bitAdd(String key, int offset, boolean b) {
return valueOps().setBit(key, offset, b);
}
/**
* 从bitmap中获取偏移量的值
* @param key key
* @param offset 偏移量
* @return 结果
*/
@Override
public Boolean bitGet(String key, int offset) {
return valueOps().getBit(key, offset);
}
/**
* 获取bitmap的key值总和
* @param key key
* @return 总和
*/
@Override
public Long bitCount(String key) {
return redisTemplate.execute((RedisCallback) con -> con.bitCount(key.getBytes()));
}
/**
* 获取bitmap范围值
* @param key key
* @param limit 范围
* @param offset 开始偏移量
* @return long类型集合
*/
@Override
public List bitField(String key, int limit, int offset) {
return redisTemplate.execute((RedisCallback>) con -> con.bitField(key.getBytes(),
BitFieldSubCommands.create().get(BitFieldSubCommands.BitFieldType.unsigned(limit)).valueAt(offset)));
}
/**
* 获取所有bitmap
* @param key key
* @return 以二进制字节数组返回
*/
@Override
public byte[] bitGetAll(String key) {
return redisTemplate.execute((RedisCallback) con -> con.get(key.getBytes()));
}
/**
* 增加坐标
* @param key key
* @param x x
* @param y y
* @param name 地点名称
* @return 返回结果
*/
@Override
public Long geoAdd(String key, Double x, Double y, String name) {
return geoOps().add(key, new Point(x, y), name);
}
/**
* 根据城市名称获取坐标集合
* @param key key
* @param place 地点
* @return 坐标集合
*/
@Override
public List geoGetPointList(String key, Object... place) {
return geoOps().position(key, place);
}
/**
* 计算两个城市之间的距离
* @param key key
* @param placeOne 地点1
* @param placeTow 地点2
* @return 返回距离
*/
@Override
public Distance geoCalculationDistance(String key, String placeOne, String placeTow) {
return geoOps().distance(key, placeOne, placeTow, RedisGeoCommands.DistanceUnit.KILOMETERS);
}
/**
* 获取附该地点附近的其他地点
* @param key key
* @param place 地点
* @param distance 附近的范围
* @param limit 查几条
* @param sort 排序规则
* @return 返回附近的地点集合
*/
@Override
public GeoResults> geoNearByPlace(String key, String place, Distance distance,
long limit, Sort.Direction sort) {
RedisGeoCommands.GeoRadiusCommandArgs args = RedisGeoCommands.GeoRadiusCommandArgs.newGeoRadiusArgs()
.includeDistance()
.includeCoordinates();
// 判断排序方式
if (Sort.Direction.ASC == sort) {
args.sortAscending();
}
else {
args.sortDescending();
}
args.limit(limit);
return geoOps().radius(key, place, distance, args);
}
/**
* 获取地点的hash
* @param key key
* @param place 地点
* @return 返回集合
*/
@Override
public List geoGetHash(String key, String... place) {
return geoOps().hash(key, place);
}
/**
* Get Helper class that simplifies Redis data access code.
* @return RedisTemplate 获取
*/
@Override
protected RedisTemplate getTemplate() {
return redisTemplate;
}
}