您的位置:首页 > 数据库 > Redis

【Redis】Java之Redis工具类

2017-05-18 22:00 344 查看
我就不介绍Redis是什么了。

(一个月前写的工具类,一直忘记分享了,算是比较全的Java-Redis工具类)

直接上代码吧。

先给出在spring 中配置Redis的代码。你在其他类用的时候,直接用注解自动注入就可以了。

redis.properties

##访问地址
redis.host=127.0.0.1
##访问端口
redis.port=6379
##注意,如果没有password,此处不设置值,但这一项要保留
redis.password=你的密码

#最大能够保持idel状态的对象数
redis.maxIdle=150
#连接池的最大数据库连接数。设为0表示无限制 最大分配的对象数
redis.maxActive=300
#连接耗尽时是否阻塞, false报异常,ture阻塞直到超时, 默认true
redis.blockWhenExhausted=true
#获取连接时的最大等待毫秒数(如果设置为阻塞时BlockWhenExhausted),如果超时就抛异常, 小于零:阻塞不确定的时间,  默认-1
redis.maxWait=10000
#在borrow一个jedis实例时,是否提前进行alidate操作;如果为true,则得到的jedis实例均是可用的;
redis.testOnBorrow=true
#jedis调用returnObject方法时,是否进行有效检查 #
redis.testOnReturn=true
#在空闲时检查有效性, 默认false
redis.testWhileIdle=true
#表示idle object evitor两次扫描之间要sleep的毫秒数;
redis.timeBetweenEvictionRunsMillis=30000
#表示一个对象至少停留在idle状态的最短时间,
#然后才能被idle object evitor扫描并驱逐;这一项只有在timeBetweenEvictionRunsMillis大于0时才有意义;
redis.minEvictableIdleTimeMillis=-1

#连接空闲的最小时间,达到此值后空闲链接将会被移除,且保留“minIdle”个空闲连接数。
#如果minEvictableIdleTimeMillis>0,则此项设置无意义,且只有在timeBetweenEvictionRunsMillis大于0时才有意义;
redis.softMinEvictableIdleTimeMillis=60000


spring.xml中配置redis

<!-- S Redis 配置-->
<!-- scanner redis properties  -->
<context:property-placeholder location="classpath:redis.properties" ignore-unresolvable="true"/>
<!--(1)如果你有多个数据源需要通过
<context:property-placeholder管理,且不愿意放在一个配置文件里,
那么一定要加上ignore-unresolvable=“true"(每一个都需要加这个属性)-->
<!--(2)注意新版的(从3.0版本开始弃用)JedisPoolConfig的property name,
不是maxActive而是maxTotal,而且没有maxWait属性,建议看一下Jedis源码。-->
<!-- redis连接池 -->
<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
<property name="maxTotal" value="${redis.maxActive}"></property>
<property name="maxIdle" value="${redis.maxIdle}"></property>
<property name="maxWaitMillis" value="${redis.maxWait}"></property>
<property name="testOnBorrow" value="${redis.testOnBorrow}"></property>
<property name="testOnReturn" value="${redis.testOnReturn}"></property>
<property name="blockWhenExhausted" value="${redis.blockWhenExhausted}"></property>
<property name="testWhileIdle" value="${redis.testWhileIdle}"></property>
<property name="timeBetweenEvictionRunsMillis" value="${redis.timeBetweenEvictionRunsMillis}"></property>
<property name="minEvictableIdleTimeMillis" value="${redis.minEvictableIdleTimeMillis}"></property>
<property name="softMinEvictableIdleTimeMillis" value="${redis.softMinEvictableIdleTimeMillis}"></property>
</bean>
<!-- redis连接工厂 -->
<bean id="connectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"
p:host-name="${redis.host}" p:port="${redis.port}" p:password="${redis.password}"  p:pool-config-ref="jedisPoolConfig"
p:usePool="true"/>
<!-- redis操作模板,这里采用尽量面向对象的模板 -->
<!--<bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
使用上句会无法使用模糊匹配
-->
<!--
p:enable-transaction-support="false"
设置setEnableTransactionSupport(true),当前线程会强制先 MULTI命令
-->
<bean id="redisTemplate" class="org.springframework.data.redis.core.StringRedisTemplate"
p:enable-transaction-support="true">
<property name="connectionFactory" ref="connectionFactory"/>
<!-- 如果不配置Serializer,那么存储的时候只能使用String,如果用对象类型存储,那么会提示错误 can't cast to String!!!-->
<property name="keySerializer">
<!--对key的默认序列化器。默认值是StringSerializer-->
<bean class="org.springframework.data.redis.serializer.StringRedisSerializer"/>
</property>
<!--是对value的默认序列化器,默认值是取自DefaultSerializer的JdkSerializationRedisSerializer。-->
<property name="valueSerializer">
<bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer"/>
</property>
<!--存储Map时key需要的序列化配置-->
<property name="hashKeySerializer">
<bean class="org.springframework.data.redis.serializer.StringRedisSerializer"/>
</property>
<!--存储Map时value需要的序列化配置-->
<property name="hashValueSerializer">
<bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer"/>
</property>
<!--开启事务
系统自动帮我们拿到了事务中绑定的连接。可以在一个方法的多次对Redis增删该查中,始终使用同一个连接。
-->
<property name="enableTransactionSupport" value="true"/>
<!--在Spring中@Transactional 也是可以进行事物控制的。-->
</bean>
<!-- 缓存管理器: 使用redis 当做缓存 -->
<!--<bean id="cacheManager" class="org.springframework.data.redis.cache.RedisCacheManager">-->
<!--<constructor-arg ref="redisTemplate"/>-->
<!--</bean>-->
<!-- cache配置 -->
<!-- E Redis 配置-->


Redis操作的接口

package com.uifuture.utils.redis;

import org.springframework.data.redis.connection.DataType;
import org.springframework.data.redis.core.ValueOperations;
import org.springframework.data.redis.core.ZSetOperations;
import org.springframework.util.CollectionUtils;

import java.io.Serializable;
import java.util.*;
import java.util.concurrent.TimeUnit;

/**
* Created with IntelliJ IDEA.
* User: 陈浩翔.
* Date: 2017/4/10.
* Time: 上午 12:11.
* Explain: Redis操作的接口
*/
public interface RedisCommand<K, V> {

/**
* 用户排序通过注册时间的 权重值
* @param date
* @return
*/
double getCreateTimeScore(long date);
/**
* 获取Redis中所有的键的key
* @return
*/
Set<K> getAllKeys();

/**
* 获取所有的普通key-value
* @return
*/
Map<K,V> getAllString();

/**
* 获取所有的Set -key-value
* @return
*/
Map<K,Set<V>> getAllSet();
/**
* 获取所有的ZSet正序  -key-value 不获取权重值
* @return
*/
Map<K,Set<V>> getAllZSetReverseRange();
/**
* 获取所有的ZSet倒序  -key-value 不获取权重值
* @return
*/
Map<K,Set<V>> getAllZSetRange();

/**
* 获取所有的List -key-value
* @return
*/
Map<K,List<V>> getAllList();

/**
* 获取所有的Map -key-value
* @return
*/
Map<K,Map<K,V>> getAllMap();

/**
* 添加一个list
* @param key
* @param objectList
*/
void addList(K key, List<V> objectList);
/**
* 向list中增加值
* @param key
* @param obj
* @return 返回在list中的下标
*/
long addList(K key,V obj);
/**
*
* 向list中增加值
* @param key
* @param obj
* @return 返回在list中的下标
*/
long addList(K key,V ...obj);

/**
*
* 输出list
* @param key List的key
* @param s 开始下标
* @param e 结束的下标
* @return
*/
List<V> getList(K key, long s, long e);
/**
* 输出完整的list
* @param key
*/
List<V> getList(K key);
/**
* 获取list集合中元素的个数
* @param key
* @return
*/
long getListSize(K key);
/**
* 移除list中某值
* 移除list中 count个value为object的值,并且返回移除的数量,
* 如果count为0,或者大于list中为value为object数量的总和,
* 那么移除所有value为object的值,并且返回移除数量
* @param key
* @param object
* @return 返回移除数量
*/
long removeListValue(K key,V object);
/**
* 移除list中某值
* @param key
* @param object
* @return 返回移除数量
*/
long removeListValue(K key,V... object);

/**
* 批量删除key对应的value
* @param keys
*/
void remove(final K... keys);
/**
* 删除缓存
* 根据key精确匹配删除
* @param key
*/
void remove(final K key);

/**
* 通过分数删除ZSet中的值
* @param key
* @param s
* @param e
*/
void removeZSetRangeByScore(String key,double s , double e);
/**
* 设置Set的过期时间
* @param key
* @param time
* @return
*/
Boolean setSetExpireTime(String key,Long time);

/**
* 设置ZSet的过期时间
* @param key
* @param time
* @return
*/
Boolean setZSetExpireTime(String key,Long time);
/**
* 判断缓存中是否有key对应的value
* @param key
* @return
*/
boolean exists(final K key);

/**
* 读取String缓存 可以是对象
* @param key
* @return
*/
V get(final K key);
/**
* 读取String缓存 可以是对象
* @param key
* @return
*/
List<V> get(final K... key);
/**
* 读取缓存 可以是对象 根据正则表达式匹配
* @param regKey
* @return
*/
List<Object> getByRegular(final K regKey);

/**
* 写入缓存 可以是对象
* @param key
* @param value
*/
void set(final K key, V value);

/**
* 写入缓存
* @param key
* @param value
* @param expireTime 过期时间 -单位s
* @return
*/
void set(final K key, V value, Long expireTime);

/**
* 设置一个key的过期时间(单位:秒)
* @param key
* @param expireTime
* @return
*/
boolean setExpireTime(K key, Long expireTime);

/**
* 获取key的类型
* @param key
* @return
*/
DataType getType(K key);

/**
* 删除map中的某个对象
* @param key   map对应的key
* @param field map中该对象的key
*/
void removeMapField(K key, V... field);
/*
* 获取map对象
* @param key map对应的key
* @return
*/
Map<K,V> getMap(K key);
/*
* 获取map对象
* @param key map对应的key
* @return
*/
Long getMapSize(K key);
/**
* 获取map缓存中的某个对象
* @param key map对应的key
* @param field map中该对象的key
* @return
*/
<T> T getMapField(K key, K field);
/**
* 判断map中对应key的key是否存在
* @param key map对应的key
* @return
*/
Boolean hasMapKey(K key,K field);

/**
* 获取map对应key的value
* @param key map对应的key
* @return
*/
List<V> getMapFieldValue(K key);
/**
* 获取map的key
* @param key map对应的key
* @return
*/
Set<V> getMapFieldKey(K key);
/**
* 添加map
* @param key
* @param map
*/
void addMap(K key, Map<K,V> map);
/**
* 向key对应的map中添加缓存对象
* @param key   cache对象key
* @param field map对应的key
* @param value     值
*/
void addMap(K key, K field, Object value);
/**
* 向key对应的map中添加缓存对象
* @param key   cache对象key
* @param field map对应的key
* @param time 过期时间-整个MAP的过期时间
* @param value     值
*/
void addMap(K key, K field, V value,long time);

/**
* 向set中加入对象
* @param key  对象key
* @param obj  值
*/
void addSet(K key, V... obj);

/**
* 处理事务时锁定key
* @param key
*/
void watch(String key);

/**
* 移除set中的某些值
* @param key  对象key
* @param obj  值
*/
long removeSetValue(K key, V obj);
/**
* 移除set中的某些值
* @param key  对象key
* @param obj  值
*/
long removeSetValue(K key, V... obj);

/**
* 获取set的对象数
* @param key  对象key
*/
long getSetSize(K key);

/**
* 判断set中是否存在这个值
* @param key  对象key
*/
Boolean hasSetValue(K key,V obj);
/**
* 获得整个set
* @param key  对象key
*/
Set<V> getSet(K key);

/**
* 获得set 并集
* @param key
* @param otherKey
* @return
*/
Set<V> getSetUnion(K key,K otherKey);

/**
* 获得set 并集
* @param key
* @param set
* @return
*/
Set<V> getSetUnion(K key,Set<Object> set);

/**
* 获得set 交集
* @param key
* @param otherKey
* @return
*/
Set<V> getSetIntersect(K key,K otherKey);

/**
* 获得set 交集
* @param key
* @param set
* @return
*/
Set<V> getSetIntersect(K key,Set<Object> set);

/**
* 模糊移除 支持*号等匹配移除
* @param blears
*/
void removeBlear(K... blears);

/**
* 修改key名 如果不存在该key或者没有修改成功返回false
* @param oldKey
* @param newKey
* @return
*/
Boolean renameIfAbsent(String oldKey,String newKey);
/**
* 模糊移除 支持*号等匹配移除
* @param blear
*/
void removeBlear(K blear);

/**
* 根据正则表达式来移除key-value
* @param blears
*/
void removeByRegular(String... blears);

/**
* 根据正则表达式来移除key-value
* @param blears
*/
void removeByRegular(String blears);

/**
* 根据正则表达式来移除 Map中的key-value
* @param key
* @param blears
*/
void removeMapFieldByRegular(K key,K... blears);

/**
* 根据正则表达式来移除 Map中的key-value
* @param key
* @param blear
*/
void removeMapFieldByRegular(K key,K blear);

/**
* 移除key 对应的value
* @param key
* @param value
* @return
*/
Long removeZSetValue(K key, V... value);
/**
* 移除key ZSet
* @param key
* @return
*/
void removeZSet(K key);
/**
*删除,键为K的集合,索引start<=index<=end的元素子集
* @param key
* @param start
* @param end
* @return
*/
void removeZSetRange(K key,Long start,Long end);

/**
* 并集 将key对应的集合和key1对应的集合合并到key2中
* 如果分数相同的值,都会保留
* 原来key2的值会被覆盖
* @param key
* @param key1
* @param key2
*/
void setZSetUnionAndStore(String key,String key1, String key2);

/**
* 获取整个有序集合ZSET,正序
* @param key
*/
<T> T getZSetRange(K key);

/**
* 获取有序集合ZSET
* 键为K的集合,索引start<=index<=end的元素子集,正序
* @param key
* @param start 开始位置
* @param end 结束位置
*/
<T> T getZSetRange(K key,long start,long end);
/**
* 获取整个有序集合ZSET,倒序
* @param key
*/
Set<Object> getZSetReverseRange(K key);

/**
* 获取有序集合ZSET
* 键为K的集合,索引start<=index<=end的元素子集,倒序
* @param key
* @param start 开始位置
* @param end 结束位置
*/
Set<V> getZSetReverseRange(K key,long start,long end);

/**
* 通过分数(权值)获取ZSET集合 正序 -从小到大
* @param key
* @param start
* @param end
* @return
*/
Set<V> getZSetRangeByScore(String key, double start, double end);

/**
* 通过分数(权值)获取ZSET集合 倒序 -从大到小
* @param key
* @param start
* @param end
* @return
*/
Set<V> getZSetReverseRangeByScore(String key, double start, double end);

/**
* 键为K的集合,索引start<=index<=end的元素子集
* 返回泛型接口(包括score和value),正序
* @param key
* @param start
* @param end
* @return
*/
Set<ZSetOperations.TypedTuple<V>> getZSetRangeWithScores(K key, long start, long end);
/**
* 键为K的集合,索引start<=index<=end的元素子集
* 返回泛型接口(包括score和value),倒序
* @param key
* @param start
* @param end
* @return
*/
Set<ZSetOperations.TypedTuple<V>> getZSetReverseRangeWithScores(K key, long start, long end);

/**
* 键为K的集合
* 返回泛型接口(包括score和value),正序
* @param key
* @return
*/
Set<ZSetOperations.TypedTuple<V>> getZSetRangeWithScores(K key);
/**
* 键为K的集合
* 返回泛型接口(包括score和value),倒序
* @param key
* @return
*/
Set<ZSetOperations.TypedTuple<V>> getZSetReverseRangeWithScores(K key);

/**
* 键为K的集合,sMin<=score<=sMax的元素个数
* @param key
* @param sMin
* @param sMax
* @return
*/
long getZSetCountSize(K key,double sMin,double sMax);

/**
* 获取Zset 键为K的集合元素个数
* @param key
* @return
*/
long getZSetSize(K key);

/**
* 获取键为K的集合,value为obj的元素分数
* @param key
* @param value
* @return
*/
double getZSetScore(K key,V value);

/**
* 元素分数增加,delta是增量
* @param key
* @param value
* @param delta
* @return
*/
double incrementZSetScore(K key,V value,double delta);

/**
* 添加有序集合ZSET
* 默认按照score升序排列,存储格式K(1)==V(n),V(1)=S(1)
* @param key
* @param score
* @param value
* @return
*/
Boolean addZSet(String key ,double score, Object value);

/**
* 添加有序集合ZSET
* @param key
* @param value
* @return
*/
Long addZSet(K key,TreeSet<V> value);

/**
* 添加有序集合ZSET
* @param key
* @param score
* @param value
* @return
*/
Boolean addZSet(K key,double[] score, Object[] value);

}


Redis的工具类

package com.uifuture.utils.redis;

import org.apache.log4j.Logger;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.connection.DataType;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.ZSetOperations;
import org.springframework.stereotype.Component;
import org.springframework.util.CollectionUtils;

import java.util.*;
import java.util.concurrent.TimeUnit;
import java.util.regex.Pattern;

/**
* Created with IntelliJ IDEA.
* User: 陈浩翔.
* Date: 2017/4/10.
* Time: 上午 12:51.
* Explain: Redis的工具类
* 增删改 -不能在这里面抓取异常 -因为可能有事务处理
*/
@Component
public class RedisHandle implements RedisCommand<String, Object> {
private Logger logger = Logger.getLogger(RedisHandle.class);
@Autowired
protected RedisTemplate redisTemplate;
/**
* 出异常,重复操作的次数
*/
private static Integer times = 5;

@Override
public double getCreateTimeScore(long date) {
return date/ 100000.0;
}

@Override
public Set<String> getAllKeys() {
return redisTemplate.keys("*");
}

@Override
public Map<String, Object> getAllString() {
Set<String> stringSet = getAllKeys();
Map<String, Object> map = new HashMap<String, Object>();
Iterator<String> iterator = stringSet.iterator();
while (iterator.hasNext()) {
String k = iterator.next();
if (getType(k) == DataType.STRING) {
map.put(k, get(k));
}
}
return map;
}

@Override
public Map<String, Set<Object>> getAllSet() {
Set<String> stringSet = getAllKeys();
Map<String, Set<Object>> map = new HashMap<String, Set<Object>>();
Iterator<String> iterator = stringSet.iterator();
while (iterator.hasNext()) {
String k = iterator.next();
if (getType(k) == DataType.SET) {
map.put(k, getSet(k));
}
}
return map;
}

@Override
public Map<String, Set<Object>> getAllZSetRange() {
Set<String> stringSet = getAllKeys();
Map<String, Set<Object>> map = new HashMap<String, Set<Object>>();
Iterator<String> iterator = stringSet.iterator();
while (iterator.hasNext()) {
String k = iterator.next();
if (getType(k) == DataType.ZSET) {
logger.debug("k:"+k);
map.put(k, getZSetRange(k));
}
}
return map;
}

@Override
public Map<String, Set<Object>> getAllZSetReverseRange() {
Set<String> stringSet = getAllKeys();
Map<String, Set<Object>> map = new HashMap<String, Set<Object>>();
Iterator<String> iterator = stringSet.iterator();
while (iterator.hasNext()) {
String k = iterator.next();
if (getType(k) == DataType.ZSET) {
map.put(k, getZSetReverseRange(k));
}
}
return map;
}

@Override
public Map<String, List<Object>> getAllList() {
Set<String> stringSet = getAllKeys();
Map<String, List<Object>> map = new HashMap<String, List<Object>>();
Iterator<String> iterator = stringSet.iterator();
while (iterator.hasNext()) {
String k = iterator.next();
if (getType(k) == DataType.LIST) {
map.put(k, getList(k));
}
}
return map;
}

@Override
public Map<String, Map<String, Object>> getAllMap() {
Set<String> stringSet = getAllKeys();
Map<String, Map<String, Object>> map = new HashMap<String, Map<String, Object>>();
Iterator<String> iterator = stringSet.iterator();
while (iterator.hasNext()) {
String k = iterator.next();
if (getType(k) == DataType.HASH) {
map.put(k, getMap(k));
}
}
return map;
}

@Override
public void addList(String key, List<Object> objectList) {
for (Object obj : objectList) {
addList(key, obj);
}
}

@Override
public long addList(String key, Object obj) {
return redisTemplate.boundListOps(key).rightPush(obj);
}

@Override
public long addList(String key, Object... obj) {
return redisTemplate.boundListOps(key).rightPushAll(obj);
}

@Override
public List<Object> getList(String key, long s, long e) {
return redisTemplate.boundListOps(key).range(s, e);
}

@Override
public List<Object> getList(String key) {
return redisTemplate.boundListOps(key).range(0, getListSize(key));
}

@Override
public long getListSize(String key) {
return redisTemplate.boundListOps(key).size();
}

@Override
public long removeListValue(String key, Object object) {
return redisTemplate.boundListOps(key).remove(0, object);
}

@Override
public long removeListValue(String key, Object... objects) {
long r = 0;
for (Object object : objects) {
r += removeListValue(key, object);
}
return r;
}

@Override
public void remove(String... key) {
if (key != null && key.length > 0) {
if (key.length == 1) {
remove(key[0]);
} else {
redisTemplate.delete(CollectionUtils.arrayToList(key));
}
}
}

@Override
public void removeBlear(String... blears) {
for (String blear : blears) {
removeBlear(blear);
}
}

@Override
public Boolean renameIfAbsent(String oldKey, String newKey) {
return redisTemplate.renameIfAbsent(oldKey, newKey);
}

@Override
public void removeBlear(String blear) {
redisTemplate.delete(redisTemplate.keys(blear));
}

@Override
public void removeByRegular(String... blears) {
for (String blear : blears) {
removeBlear(blear);
}
}

@Override
public void removeByRegular(String blear) {
Set<String> stringSet = getAllKeys();
for (String s : stringSet) {
if (Pattern.compile(blear).matcher(s).matches()) {
redisTemplate.delete(s);
}
}
}

@Override
public void removeMapFieldByRegular(String key, String... blears) {
for (String blear : blears) {
removeMapFieldByRegular(key, blear);
}
}

@Override
public void removeMapFieldByRegular(String key, String blear) {
Map<String, Object> map = getMap(key);
Set<String> stringSet = map.keySet();
for (String s : stringSet) {
if (Pattern.compile(blear).matcher(s).matches()) {
redisTemplate.boundHashOps(key).delete(s);
}
}
}

@Override
public Long removeZSetValue(String key, Object... value) {
return redisTemplate.boundZSetOps(key).remove(value);
}

@Override
public void removeZSet(String key) {
removeZSetRange(key, 0L, getZSetSize(key));
}

@Override
public void removeZSetRange(String key, Long start, Long end) {
redisTemplate.boundZSetOps(key).removeRange(start, end);
}

@Override
public void setZSetUnionAndStore(String key,String key1, String key2) {
redisTemplate.boundZSetOps(key).unionAndStore(key1,key2);
}

@Override
public Set<Object> getZSetRange(String key) {
return getZSetRange(key, 0, getZSetSize(key));
}

@Override
public Set<Object> getZSetRange(String key, long s, long e) {
return redisTemplate.boundZSetOps(key).range(s, e);
}

@Override
public Set<Object> getZSetReverseRange(String key) {
return getZSetReverseRange(key, 0, getZSetSize(key));
}

@Override
public Set<Object> getZSetReverseRange(String key, long start, long end) {
return redisTemplate.boundZSetOps(key).reverseRange(start, end);
}

@Override
public Set<Object> getZSetRangeByScore(String key, double start, double end) {
return redisTemplate.boundZSetOps(key).rangeByScore(start, end);
}
@Override
public Set<Object> getZSetReverseRangeByScore(String key, double start, double end) {
return redisTemplate.boundZSetOps(key).reverseRangeByScore(start, end);
}

@Override
public Set<ZSetOperations.TypedTuple<Object>> getZSetRangeWithScores(String key, long start, long end) {
return redisTemplate.boundZSetOps(key).rangeWithScores(start, end);
}

@Override
public Set<ZSetOperations.TypedTuple<Object>> getZSetReverseRangeWithScores(String key, long start, long end) {
return redisTemplate.boundZSetOps(key).reverseRangeWithScores(start, end);
}

@Override
public Set<ZSetOperations.TypedTuple<Object>> getZSetRangeWithScores(String key) {
return getZSetRangeWithScores(key, 0, getZSetSize(key));
}

@Override
public Set<ZSetOperations.TypedTuple<Object>> getZSetReverseRangeWithScores(String key) {
return getZSetReverseRangeWithScores(key, 0, getZSetSize(key));
}

@Override
public long getZSetCountSize(String key, double sMin, double sMax) {
return redisTemplate.boundZSetOps(key).count(sMin, sMax);
}

@Override
public long getZSetSize(String key) {
return redisTemplate.boundZSetOps(key).size();
}

@Override
public double getZSetScore(String key, Object value) {
return redisTemplate.boundZSetOps(key).score(value);
}

@Override
public double incrementZSetScore(String key, Object value, double delta) {
return redisTemplate.boundZSetOps(key).incrementScore(value, delta);
}

@Override
public Boolean addZSet(String key, double score, Object value) {
return redisTemplate.boundZSetOps(key).add(value, score);
}

@Override
public Long addZSet(String key, TreeSet<Object> value) {
return redisTemplate.boundZSetOps(key).add(value);
}

@Override
public Boolean addZSet(String key, double[] score, Object[] value) {
if (score.length != value.length) {
return false;
}
for (int i = 0; i < score.length; i++) {
if (addZSet(key, score[i], value[i]) == false) {
return false;
}
}
return true;
}

@Override
public void remove(String key) {
if (exists(key)) {
redisTemplate.delete(key);
}
}

@Override
public void removeZSetRangeByScore(String key,double s , double e) {
redisTemplate.boundZSetOps(key).removeRangeByScore(s,e);
}

@Override
public Boolean setSetExpireTime(String key, Long time) {
return redisTemplate.boundSetOps(key).expire(time, TimeUnit.SECONDS);
}

@Override
public Boolean setZSetExpireTime(String key, Long time) {
return redisTemplate.boundZSetOps(key).expire(time, TimeUnit.SECONDS);
}

@Override
public boolean exists(String key) {
return redisTemplate.hasKey(key);
}

@Override
public Object get(String key) {
return redisTemplate.boundValueOps(key).get();
}

@Override
public List<Object> get(String... keys) {
List<Object> list = new ArrayList<Object>();
for (String key : keys) {
list.add(get(key));
}
return list;
}

@Override
public List<Object> getByRegular(String regKey) {
Set<String> stringSet = getAllKeys();
List<Object> objectList = new ArrayList<Object>();
for (String s : stringSet) {
if (Pattern.compile(regKey).matcher(s).matches() && getType(s) == DataType.STRING) {
objectList.add(get(s));
}
}
return objectList;
}

@Override
public void set(String key, Object value) {
redisTemplate.boundValueOps(key).set(value);
}

@Override
public void set(String key, Object value, Long expireTime) {
redisTemplate.boundValueOps(key).set(value, expireTime, TimeUnit.SECONDS);
}

@Override
public boolean setExpireTime(String key, Long expireTime) {
return redisTemplate.expire(key, expireTime, TimeUnit.SECONDS);
}

@Override
public DataType getType(String key) {
return redisTemplate.type(key);
}

@Override
public void removeMapField(String key, Object... field) {
redisTemplate.boundHashOps(key).delete(field);
}

@Override
public Long getMapSize(String key) {
return redisTemplate.boundHashOps(key).size();
}

@Override
public Map<String, Object> getMap(String key) {
return redisTemplate.boundHashOps(key).entries();
}

@Override
public <T> T getMapField(String key, String field) {
return (T) redisTemplate.boundHashOps(key).get(field);
}

@Override
public Boolean hasMapKey(String key, String field) {
return redisTemplate.boundHashOps(key).hasKey(field);
}

@Override
public List<Object> getMapFieldValue(String key) {
return redisTemplate.boundHashOps(key).values();
}

@Override
public Set<Object> getMapFieldKey(String key) {
return redisTemplate.boundHashOps(key).keys();
}

@Override
public void addMap(String key, Map<String, Object> map) {
redisTemplate.boundHashOps(key).putAll(map);
}

@Override
public void addMap(String key, String field, Object value) {
redisTemplate.boundHashOps(key).put(field, value);
}

@Override
public void addMap(String key, String field, Object value, long time) {
redisTemplate.boundHashOps(key).put(field, value);
redisTemplate.boundHashOps(key).expire(time, TimeUnit.SECONDS);
}

@Override
public void watch(String key) {
redisTemplate.watch(key);
}

@Override
public void addSet(String key, Object... obj) {
redisTemplate.boundSetOps(key).add(obj);
}

@Override
public long removeSetValue(String key, Object obj) {
return redisTemplate.boundSetOps(key).remove(obj);
}

@Override
public long removeSetValue(String key, Object... obj) {
if (obj != null && obj.length > 0) {
return redisTemplate.boundSetOps(key).remove(obj);
}
return 0L;
}

@Override
public long getSetSize(String key) {
return redisTemplate.boundSetOps(key).size();
}

@Override
public Boolean hasSetValue(String key, Object obj) {
Boolean boo = null;
int t =0;
while (true){
try {
boo = redisTemplate.boundSetOps(key).isMember(obj);
break;
} catch (Exception e) {
logger.error("key[" + key + "],obj[" + obj + "]判断Set中的值是否存在失败,异常信息:" + e.getMessage());
t++;
}
if(t>times){
break;
}
}
logger.info("key[" + key + "],obj[" + obj + "]是否存在,boo:" + boo);
return boo;
}

@Override
public Set<Object> getSet(String key) {
return redisTemplate.boundSetOps(key).members();
}

@Override
public Set<Object> getSetUnion(String key, String otherKey) {
return redisTemplate.boundSetOps(key).union(otherKey);
}

@Override
public Set<Object> getSetUnion(String key, Set<Object> set) {
return redisTemplate.boundSetOps(key).union(set);
}

@Override
public Set<Object> getSetIntersect(String key, String otherKey) {
return redisTemplate.boundSetOps(key).intersect(otherKey);
}

@Override
public Set<Object> getSetIntersect(String key, Set<Object> set) {
return redisTemplate.boundSetOps(key).intersect(set);
}

}


这个是我当时写一个Web项目的时候,慢慢整合而成的,比较完整的Redis操作工具类,基本上可以满足你操纵Redis的绝大多数需要了。

因为不是个什么完整的项目,就没有上传到github上为大家提供这几个代码的下载了,只能麻烦需要的朋友直接拷贝下了。

本文章由[谙忆]编写, 所有权利保留。

欢迎转载,分享是进步的源泉。

转载请注明出处:http://chenhaoxiang.cn

本文源自人生之旅_谙忆的博客
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: