Redis使用简明教程
来源:互联网 发布:java 获取对象的大小 编辑:程序博客网 时间:2024/05/29 19:06
一)安装redis
1)redis的安装
详情参考百度经验 Windows 64位下安装Redis详细教程
二)基本简介
Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库。
Redis 与其他 key - value 缓存产品有以下三个特点:
Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
Redis支持数据的备份,即master-slave模式的数据备份。
更多参考: Redis菜鸟教程
redis存储数据类型主要有5种:
String最基本类型,最大为512M内容;
hash是一个键名对集合 是一个String类型的field和value的映射表,适合存储对象,每个hash可以存储2^32-1的键值对;
list列表是按照简单的字符串列表,按照顺序出入顺序排列,可以添加一个元素的到列表尾部或者头部,列表最多可存储 232 - 1 元素;
Set集合是通过哈希表实现的String类型的无序集合,删除添加复杂度为O(1),集合中最大的成员数为 232 - 1;
zset(sorted set:有序集合),Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
Redis保存的数据类型是通过key-value形式存储对应的数据,这些存储的数据转换转换成上面5种类型的格式的数据,当然这几种类型格式数据使用者可以进一步封装成自己需要的风格。具体参考下面Redis工具类。
三)简单实例应用
package com.test;import java.util.HashMap;import java.util.Iterator;import java.util.List;import java.util.Map;import org.junit.Before;import org.junit.Test;import redis.clients.jedis.Jedis;public class TestRedis { private Jedis jedis; @Before public void setup() { //连接redis服务器,192.168.0.83:1421 jedis = new Jedis("192.168.0.83", 6379); //权限认证 jedis.auth("admin"); } /** * redis存储字符串 */ @Test public void testString() { //-----添加数据---------- jedis.set("name","xinxin");//向key-->name中放入了value-->xinxin System.out.println(jedis.get("name"));//执行结果:xinxin jedis.append("name", " is my lover"); //拼接 System.out.println(jedis.get("name")); jedis.del("name"); //删除某个键 System.out.println(jedis.get("name")); //设置多个键值对 jedis.mset("name","liuling","age","23","qq","476777XXX"); jedis.incr("age"); //进行加1操作 System.out.println(jedis.get("name") + "-" + jedis.get("age") + "-" + jedis.get("qq")); } /** * redis操作Map */ @Test public void testMap() { //-----添加数据---------- Map<String, String> map = new HashMap<String, String>(); map.put("name", "xinxin"); map.put("age", "22"); map.put("qq", "123456"); jedis.hmset("user",map); //取出user中的name,执行结果:[minxr]-->注意结果是一个泛型的List //第一个参数是存入redis中map对象的key,后面跟的是放入map中的对象的key,后面的key可以跟多个,是可变参数 List<String> rsmap = jedis.hmget("user", "name", "age", "qq"); System.out.println(rsmap); //删除map中的某个键值 jedis.hdel("user","age"); System.out.println(jedis.hmget("user", "age")); //因为删除了,所以返回的是null System.out.println(jedis.hlen("user")); //返回key为user的键中存放的值的个数2 System.out.println(jedis.exists("user"));//是否存在key为user的记录 返回true System.out.println(jedis.hkeys("user"));//返回map对象中的所有key System.out.println(jedis.hvals("user"));//返回map对象中的所有value Iterator<String> iter=jedis.hkeys("user").iterator(); while (iter.hasNext()){ String key = iter.next(); System.out.println(key+":"+jedis.hmget("user",key)); } } /** * jedis操作List */ @Test public void testList(){ //开始前,先移除所有的内容 jedis.del("java framework"); System.out.println(jedis.lrange("java framework",0,-1)); //先向key java framework中存放三条数据 jedis.lpush("java framework","spring"); jedis.lpush("java framework","struts"); jedis.lpush("java framework","hibernate"); //再取出所有数据jedis.lrange是按范围取出, // 第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度 -1表示取得所有 System.out.println(jedis.lrange("java framework",0,-1)); jedis.del("java framework"); jedis.rpush("java framework","spring"); jedis.rpush("java framework","struts"); jedis.rpush("java framework","hibernate"); System.out.println(jedis.lrange("java framework",0,-1)); } /** * jedis操作Set */ @Test public void testSet(){ //添加 jedis.sadd("user","liuling"); jedis.sadd("user","xinxin"); jedis.sadd("user","ling"); jedis.sadd("user","zhangxinxin"); jedis.sadd("user","who"); //移除noname jedis.srem("user","who"); System.out.println(jedis.smembers("user"));//获取所有加入的value System.out.println(jedis.sismember("user", "who"));//判断 who 是否是user集合的元素 System.out.println(jedis.srandmember("user")); System.out.println(jedis.scard("user"));//返回集合的元素个数 } @Test public void test() throws InterruptedException { //jedis 排序 //注意,此处的rpush和lpush是List的操作。是一个双向链表(但从表现来看的) jedis.del("a");//先清除数据,再加入数据进行测试 jedis.rpush("a", "1"); jedis.lpush("a","6"); jedis.lpush("a","3"); jedis.lpush("a","9"); System.out.println(jedis.lrange("a",0,-1));// [9, 3, 6, 1] System.out.println(jedis.sort("a")); //[1, 3, 6, 9] //输入排序后结果 System.out.println(jedis.lrange("a",0,-1)); } @Test public void testRedisPool() { RedisUtil.getJedis().set("newname", "中文测试"); System.out.println(RedisUtil.getJedis().get("newname")); }}
四)Redis客户端管理工具
1)解压Redis客户端管理工具RedisClient后,连接本地的redis数据库,相对来说,RedisClient要比sql数据库简单很多。
1】安装
2】连接本地redis
左键——>Redis服务器——>添加服务器
3】填写信息后确认
4】内部数据信息浏览
数据的增删改查在Redis数据浏览器管理下的列表中操作,也可以设置过期时间
五)一个redis封装工具类
redis工具类主要分为6个部分:
1)过期时间设置的封装;
2)操作String封装;
3)操作list封装;
4)操作set封装;
5)操作hset封装;
package com.xiu.common.cache.redis;import java.util.List;import java.util.Map;import java.util.Properties;import java.util.Set;import javax.annotation.PostConstruct;import org.apache.commons.lang3.StringUtils;import redis.clients.jedis.BinaryClient;import redis.clients.jedis.Jedis;import redis.clients.jedis.JedisPool;import redis.clients.jedis.JedisPoolConfig;import redis.clients.jedis.SortingParams;import redis.clients.jedis.exceptions.JedisConnectionException;import redis.clients.jedis.exceptions.JedisDataException;import redis.clients.jedis.exceptions.JedisException;import redis.clients.util.SafeEncoder;import com.xiu.common.Loggers;/** *Redis工具类 * */public class RedisService{ private RedisConfig redisConfig; private JedisPoolConfig jedisPoolConfig; private JedisPool jedisPool; public RedisService(Properties properties) { this.redisConfig = new RedisConfig(properties); } /** * Spring启动时加载该类构造器,初始化redis * @throws RuntimeException */ @PostConstruct public void start() throws RuntimeException { initJedisPoolConfig(); initJedisPool(); } // @Override// public LifecycleType getType() {// return LifecycleType.REDIS;// }//// @Override// public void start() throws RuntimeException {// initJedisPoolConfig();// initJedisPool();// }//// @Override// public void stop() throws RuntimeException {// this.jedisPool.destroy();// } private void initJedisPoolConfig() { jedisPoolConfig = new JedisPoolConfig(); jedisPoolConfig.setMaxTotal(redisConfig.getMaxActive()); jedisPoolConfig.setMaxIdle(redisConfig.getMaxIdle()); jedisPoolConfig.setMaxWaitMillis(redisConfig.getMaxWait()); jedisPoolConfig.setTestOnBorrow(redisConfig.isTestOnBorrow()); jedisPoolConfig.setTestOnReturn(redisConfig.isTestOnReturn()); } private void initJedisPool() { if (!redisConfig.getPassword().equalsIgnoreCase("null") && StringUtils.isNotBlank(redisConfig.getPassword())) { jedisPool = new JedisPool(jedisPoolConfig, redisConfig.getHost(), redisConfig.getPort(), redisConfig.getTimeout(), redisConfig.getPassword()); } else { jedisPool = new JedisPool(jedisPoolConfig, redisConfig.getHost(), redisConfig.getPort(), redisConfig.getTimeout()); } } private void handleJedisException(JedisException jedisException) { if (jedisException instanceof JedisConnectionException) { Loggers.REDIS.error("Redis connection " + /**jedisPool.getAddress() + */" lost.", jedisException); } else if (jedisException instanceof JedisDataException) { if ((jedisException.getMessage() != null) && (jedisException.getMessage().contains("READONLY"))) { Loggers.REDIS.error("Redis connection " + /**jedisPool.getAddress() +*/" are read-only slave.", jedisException); } else { // dataException, isBroken=false } } else { Loggers.REDIS.error("Jedis exception happen.", jedisException); } } /** * 设置过期时间 * * @author ruan 2013-4-11 * @param key * @param seconds * @return 影响的记录数 */ public long expire(String key, int seconds) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.expire(key, seconds); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 设置默认过期时间 * * @param key * @return 影响的记录数 */ public long expire(String key) { return expire(key, redisConfig.getExpire()); } // *******************************************Keys*******************************************// /** * 清空所有key */ public String flushAll() { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.flushAll(); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 更改key * * @param oldkey * @param newkey * @return 状态码 */ public String rename(String oldkey, String newkey) { return rename(SafeEncoder.encode(oldkey), SafeEncoder.encode(newkey)); } /** * 更改key,仅当新key不存在时才执行 * * @param oldkey * @param newkey * @return 状态码 */ public long renamenx(String oldkey, String newkey) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.renamenx(oldkey, newkey); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 更改key * * @param oldkey * @param newkey * @return 状态码 */ public String rename(byte[] oldkey, byte[] newkey) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.rename(oldkey, newkey); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } }// /**// * 设置key的过期时间,以秒为单位// *// * @param key// * @param seconds 单位:秒// * @return 影响的记录数// */// public long expired(String key, int seconds) {// Jedis jedis = null;// try {// jedis = jedisPool.getResource();// return jedis.expire(key, seconds);// } catch (JedisException e) {// handleJedisException(e);// throw e;// } finally {// if (jedis != null) {// jedis.close();// }// }// } /** * 设置key的过期时间,它是距历元(即格林威治标准时间 1970 年 1 月 1 日的 00:00:00,格里高利历)的偏移量。 * * @param key * @param timestamp * @return 影响的记录数 */ public long expireAt(String key, long timestamp) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.expireAt(key, timestamp); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 查询key的过期时间 * * @param key * @return 以秒为单位的时间表示 */ public long ttl(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.ttl(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 取消对key过期时间的设置 * * @param key * @return 影响的记录数 */ public long persist(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.persist(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 删除keys对应的记录,可以是多个key * * @param keys * @return 删除的记录数 */ public long del(String... keys) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.del(keys); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 删除keys对应的记录,可以是多个key * * @param keys * @return 删除的记录数 */ public long del(byte[]... keys) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.del(keys); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 判断key是否存在 * * @param key * @return boolean */ public boolean exists(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.exists(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 对List,Set,SortSet进行排序,如果集合数据较大应避免使用这个方法 * * @param key * @return List<String> 集合的全部记录 */ public List<String> sort(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.sort(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 对List,Set,SortSet进行排序或limit * * @param key * @param parameters 定义排序类型或limit的起止位置. * @return List<String> 全部或部分记录 */ public List<String> sort(String key, SortingParams parameters) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.sort(key, parameters); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 返回指定key存储的类型 * * @param key * @return String string|list|set|zset|hash */ public String type(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.type(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 查找所有匹配给定的模式的键 * * @param pattern key的表达式,*表示多个,?表示一个 * */ public Set<String> keys(String pattern) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.keys(pattern); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } // *******************************************Sets*******************************************// /** * 向Set添加一条记录,如果member已存在返回0,否则返回1 * * @param key * @param member * @return 操作码,0或1 */ public long sadd(String key, String member) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.sadd(key, member); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } public long sadd(byte[] key, byte[] member) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.sadd(key, member); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获取给定key中元素个数 * * @param key * @return 元素个数 */ public long scard(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.scard(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 返回从第一组和所有的给定集合之间的差异的成员 * * @param keys * @return 差异的成员集合 */ public Set<String> sdiff(String... keys) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.sdiff(keys); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 这个命令等于sdiff,但返回的不是结果集,而是将结果集存储在新的集合中,如果目标已存在,则覆盖。 * * @param newkey 新结果集的key * @param keys 比较的集合 * @return 新集合中的记录数 */ public long sdiffstore(String newkey, String... keys) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.sdiffstore(newkey, keys); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 返回给定集合交集的成员,如果其中一个集合为不存在或为空,则返回空Set * * @param keys * @return 交集成员的集合 */ public Set<String> sinter(String... keys) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.sinter(keys); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 这个命令等于sinter,但返回的不是结果集,而是将结果集存储在新的集合中,如果目标已存在,则覆盖。 * * @param newkey 新结果集的key * @param keys 比较的集合 * @return 新集合中的记录数 */ public long sinterstore(String newkey, String... keys) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.sinterstore(newkey, keys); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 确定一个给定的值是否存在 * * @param key * @param member 要判断的值 * @return 存在返回1,不存在返回0 */ public boolean sismember(String key, String member) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.sismember(key, member); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 返回集合中的所有成员 * * @param key * @return 成员集合 */ public Set<String> smembers(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.smembers(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } public Set<byte[]> smembers(byte[] key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.smembers(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 将成员从源集合移出放入目标集合 <br/> * 如果源集合不存在或不包哈指定成员,不进行任何操作,返回0<br/> * 否则该成员从源集合上删除,并添加到目标集合,如果目标集合中成员已存在,则只在源集合进行删除 * * @param srckey 源集合 * @param dstkey 目标集合 * @param member 源集合中的成员 * @return 状态码,1成功,0失败 */ public long smove(String srckey, String dstkey, String member) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.smove(srckey, dstkey, member); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 从集合中删除成员 * * @param key * @return 被删除的成员 */ public String spop(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.spop(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 从集合中删除指定成员 * * @param key * * @param member 要删除的成员 * @return 状态码,成功返回1,成员不存在返回0 */ public long srem(String key, String member) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.srem(key, member); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 合并多个集合并返回合并后的结果,合并后的结果集合并不保存<br/> * * @param keys * @return 合并后的结果集合 */ public Set<String> sunion(String... keys) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.sunion(keys); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 合并多个集合并将合并后的结果集保存在指定的新集合中,如果新集合已经存在则覆盖 * * @param newkey 新集合的key * @param keys 要合并的集合 */ public long sunionstore(String newkey, String... keys) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.sunionstore(newkey, keys); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } // *******************************************SortSet*******************************************// /** * 向集合中增加一条记录,如果这个值已存在,这个值对应的权重将被置为新的权重 * * @param key * @param score 权重 * @param member 要加入的值 * @return 状态码 1成功,0已存在member的值 */ public long zadd(String key, double score, String member) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zadd(key, score, member); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } public long zadd(String key, Map<String, Double> scoreMembers) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zadd(key, scoreMembers); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获取集合中元素的数量 * * @param key * @return 如果返回0则集合不存在 */ public long zcard(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zcard(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获取指定权重区间内集合的数量 * * @param key * * @param min 最小排序位置 * @param max 最大排序位置 */ public long zcount(String key, double min, double max) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zcount(key, min, max); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获得set的长度 * * @param key * @return */ public long zlength(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zrange(key, 0, -1).size(); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 权重增加给定值,如果给定的member已存在 * * @param key * @param score 要增的权重 * @param member 要插入的值 * @return 增后的权重 */ public double zincrby(String key, double score, String member) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zincrby(key, score, member); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 返回指定位置的集合元素,0为第一个元素,-1为最后一个元素 * * @param key * @param start 开始位置(包含) * @param end 结束位置(包含) * @return Set<String> */ public Set<String> zrange(String key, int start, int end) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zrange(key, start, end); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 返回指定权重区间的元素集合 * * @param key * @param min 上限权重 * @param max 下限权重 * @return Set<String> */ public Set<String> zrangeByScore(String key, double min, double max) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zrangeByScore(key, min, max); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获取指定值在集合中的位置,集合排序从低到高 * * @param key * @param member * @return long 位置 */ public long zrank(String key, String member) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zrank(key, member); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获取指定值在集合中的位置,集合排序从高到低 * * @param key * @param member * @return long 位置 */ public long zrevrank(String key, String member) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zrevrank(key, member); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 从集合中删除成员 * * @param key * @param member * @return 返回1成功 */ public long zrem(String key, String member) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zrem(key, member); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 删除 * * @param key * @return */ public long zrem(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.del(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 删除给定位置区间的元素 * * @param key * @param start 开始区间,从0开始(包含) * @param end 结束区间,-1为最后一个元素(包含) * @return 删除的数量 */ public long zremrangeByRank(String key, int start, int end) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zremrangeByRank(key, start, end); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 删除给定权重区间的元素 * * @param key * @param min 下限权重(包含) * @param max 上限权重(包含) * @return 删除的数量 */ public long zremrangeByScore(String key, double min, double max) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zremrangeByScore(key, min, max); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获取给定区间的元素,原始按照权重由高到低排序 * * @param key * @param start * @param end * @return Set<String> */ public Set<String> zrevrange(String key, int start, int end) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zrevrange(key, start, end); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获取给定值在集合中的权重 * * @param key * @param member * @return double 权重 */ public double zscore(String key, String member) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.zscore(key, member); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } // *******************************************Hash*******************************************// /** * 从hash中删除指定的存储 * * @param key * @param field 存储的名字 * @return 状态码,1成功,0失败 */ public long hdel(String key, String field) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hdel(key, field); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } public long hdel(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.del(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 测试hash中指定的存储是否存在 * * @param key * @param field 存储的名字 * @return 1存在,0不存在 */ public boolean hexists(String key, String field) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hexists(key, field); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 返回hash中指定存储位置的值 * * @param key * @param field 存储的名字 * @return 存储对应的值 */ public String hget(String key, String field) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hget(key, field); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } public byte[] hget(byte[] key, byte[] field) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hget(key, field); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 以Map的形式返回hash中的存储和值 * * @param key * @return Map<String, String> */ public Map<String, String> hgetAll(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hgetAll(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 添加一个对应关系 * * @param key * @param field * @param value * @return 状态码 1成功,0失败,field已存在将更新,也返回0 */ public long hset(String key, String field, String value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hset(key, field, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } public long hset(String key, String field, byte[] value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hset(key.getBytes(), field.getBytes(), value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 添加对应关系,只有在field不存在时才执行 * * @param key * @param field * @param value * @return 状态码 1成功,0失败field已存 */ public long hsetnx(String key, String field, String value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hsetnx(key, field, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获取hash中value的集合 * * @param key * @return List<String> */ public List<String> hvals(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hvals(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 在指定的存储位置加上指定的数字,存储位置的值必须可转为数字类型 * * @param key * @param field 存储位置 * @param value 要增加的值,可以是负数 * @return 增加指定数字后,存储位置的值 */ public long hincrby(String key, String field, long value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hincrBy(key, field, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 返回指定hash中的所有存储名字,类似Map中的keySet方法 * * @param key * @return Set<String> 存储名称的集合 */ public Set<String> hkeys(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hkeys(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获取hash中存储的个数,类似Map中size方法 * * @param key * @return long 存储的个数 */ public long hlen(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hlen(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 根据多个key,获取对应的value,返回List,如果指定的key不存在,List对应位置为null * * @param key * @param fields 存储位置 * @return List<String> */ public List<String> hmget(String key, String... fields) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hmget(key, fields); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } public List<byte[]> hmget(byte[] key, byte[]... fields) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hmget(key, fields); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 添加对应关系,如果对应关系已存在,则覆盖 * * @param key * @param map 对应关系 * @return 状态,成功返回OK */ public String hmset(String key, Map<String, String> map) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hmset(key, map); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 添加对应关系,如果对应关系已存在,则覆盖 * * @param key * @param map 对应关系 * @return 状态,成功返回OK */ public String hmset(byte[] key, Map<byte[], byte[]> map) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.hmset(key, map); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } // *******************************************Strings*******************************************// /** * 根据key获取记录 * * @param key * @return 值 */ public String get(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.get(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 根据key获取记录 * * @param key * @return 值 */ public byte[] get(byte[] key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.get(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 添加有过期时间的记录 * * @param key * @param seconds 过期时间,以秒为单位 * @param value * @return String 操作状态 */ public String setEx(String key, int seconds, String value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.setex(key, seconds, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 添加有过期时间的记录 * * @param key * @param seconds 过期时间,以秒为单位 * @param value * @return String 操作状态 */ public String setEx(byte[] key, int seconds, byte[] value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.setex(key, seconds, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 添加一条记录,仅当给定的key不存在时才插入 * * @param key * @param value * @return long 状态码,1插入成功且key不存在,0未插入,key存在 */ public long setnx(String key, String value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.setnx(key, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 添加记录,如果记录已存在将覆盖原有的value * * @param key * @param value * @return 状态码 */ public String set(String key, String value) { return set(SafeEncoder.encode(key), SafeEncoder.encode(value)); } /** * 添加记录,如果记录已存在将覆盖原有的value * * @param key * @param value * @return 状态码 */ public String set(String key, byte[] value) { return set(SafeEncoder.encode(key), value); } /** * 添加记录,如果记录已存在将覆盖原有的value * * @param key * @param value * @return 状态码 */ public String set(byte[] key, byte[] value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.set(key, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 从指定位置开始插入数据,插入的数据会覆盖指定位置以后的数据<br/> * 例:String str1="123456789";<br/> * 对str1操作后setRange(key,4,0000),str1="123400009"; * * @param key * @param offset * @param value * @return long value的长度 */ public long setRange(String key, long offset, String value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.setrange(key, offset, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 在指定的key中追加value * * @param key * @param value * @return long 追加后value的长度 */ public long append(String key, String value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.append(key, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 将key对应的value减去指定的值,只有value可以转为数字时该方法才可用 * * @param key * @param number 要减去的值 * @return long 减指定值后的值 */ public long decrBy(String key, long number) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.decrBy(key, number); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * <b>可以作为获取唯一id的方法</b><br/> * 将key对应的value加上指定的值,只有value可以转为数字时该方法才可用 * * @param key * @param number 要减去的值 * @return long 相加后的值 */ public long incrBy(String key, long number) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.incrBy(key, number); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 对指定key对应的value进行截取 * * @param key * @param startOffset 开始位置(包含) * @param endOffset 结束位置(包含) * @return String 截取的值 */ public String getrange(String key, long startOffset, long endOffset) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.getrange(key, startOffset, endOffset); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获取并设置指定key对应的value<br/> * 如果key存在返回之前的value,否则返回null * * @param key * @param value * @return String 原始value或null */ public String getSet(String key, String value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.getSet(key, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 批量获取记录,如果指定的key不存在返回List的对应位置将是null * * @param keys * @return List<String> 值得集合 */ public List<String> mget(String... keys) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.mget(keys); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 批量存储记录 * * @param keysvalues 例:keysvalues="key1","value1","key2","value2"; * @return String 状态码 */ public String mset(String... keysvalues) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.mset(keysvalues); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获取key对应的值的长度 * * @param key * @return value值得长度 */ public long strlen(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.strlen(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } public long del(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.del(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } public boolean delRetBoolean(String key) { return del(key) > 0; } public long del(byte[] keys) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.del(keys); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } public boolean delRetBoolean(byte[] keys) { return del(keys) > 0; } // *******************************************Lists*******************************************// /** * List长度 * * @param key * @return 长度 */ public long llen(String key) { return llen(SafeEncoder.encode(key)); } /** * List长度 * * @param key * @return 长度 */ public long llen(byte[] key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.llen(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 覆盖操作,将覆盖List中指定位置的值 * * @param key * @param index 位置 * @param value 值 * @return 状态码 */ public String lset(byte[] key, int index, byte[] value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.lset(key, index, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 覆盖操作,将覆盖List中指定位置的值 * * @param key * @param index 位置 * @param value 值 * @return 状态码 */ public String lset(String key, int index, String value) { return lset(SafeEncoder.encode(key), index, SafeEncoder.encode(value)); } /** * 在value的相对位置插入记录 * * @param key * @param where 前面插入或后面插入 * @param pivot 相对位置的内容 * @param value 插入的内容 * @return 记录总数 */ public long linsert(String key, BinaryClient.LIST_POSITION where, String pivot, String value) { return linsert(SafeEncoder.encode(key), where, SafeEncoder.encode(pivot), SafeEncoder.encode(value)); } /** * 在指定位置插入记录 * * @param key * @param where 前面插入或后面插入 * @param pivot 相对位置的内容 * @param value 插入的内容 * @return 记录总数 */ public long linsert(byte[] key, BinaryClient.LIST_POSITION where, byte[] pivot, byte[] value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.linsert(key, where, pivot, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获取List中指定位置的值 * * @param key * @param index 位置 * @return 值 */ public String lindex(String key, int index) { return SafeEncoder.encode(lindex(SafeEncoder.encode(key), index)); } /** * 获取List中指定位置的值 * * @param key * @param index 位置 * @return 值 */ public byte[] lindex(byte[] key, int index) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.lindex(key, index); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 将List中的第一条记录移出List * * @param key * @return 移出的记录 */ public String lpop(String key) { return SafeEncoder.encode(lpop(SafeEncoder.encode(key))); } /** * 将List中的第一条记录移出List * * @param key * @return 移出的记录 */ public byte[] lpop(byte[] key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.lpop(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 将List中最后第一条记录移出List * * @param key * @return 移出的记录 */ public String rpop(String key) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.rpop(key); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 向List尾部追加记录 * * @param key * @param value * @return 记录总数 */ public long lpush(String key, String value) { return lpush(SafeEncoder.encode(key), SafeEncoder.encode(value)); } /** * 向List头部追加记录 * * @param key * @param value * @return 记录总数 */ public long rpush(String key, String value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.rpush(key, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 向List头部追加记录 * * @param key * @param value * @return 记录总数 */ public long rpush(byte[] key, byte[] value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.rpush(key, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 向List中追加记录 * * @param key * @param value * @return 记录总数 */ public long lpush(byte[] key, byte[] value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.lpush(key, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获取指定范围的记录,可以做为分页使用 * * @param key * @param start * @param end * @return List */ public List<String> lrange(String key, long start, long end) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.lrange(key, start, end); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 获取指定范围的记录,可以做为分页使用 * * @param key * @param start * @param end 如果为负数,则尾部开始计算 * @return List */ public List<byte[]> lrange(byte[] key, int start, int end) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.lrange(key, start, end); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 删除List中c条记录,被删除的记录值为value * * @param key * @param c 要删除的数量,如果为负数则从List的尾部检查并删除符合的记录 * @param value 要匹配的值 * @return 删除后的List中的记录数 */ public long lrem(byte[] key, int c, byte[] value) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.lrem(key, c, value); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 删除List中c条记录,被删除的记录值为value * * @param key * @param c 要删除的数量,如果为负数则从List的尾部检查并删除符合的记录 * @param value 要匹配的值 * @return 删除后的List中的记录数 */ public long lrem(String key, int c, String value) { return lrem(SafeEncoder.encode(key), c, SafeEncoder.encode(value)); } /** * 算是删除吧,只保留start与end之间的记录 * * @param key * @param start 记录的开始位置(0表示第一条记录) * @param end 记录的结束位置(如果为-1则表示最后一个,-2,-3以此类推) * @return 执行状态码 */ public String ltrim(byte[] key, int start, int end) { Jedis jedis = null; try { jedis = jedisPool.getResource(); return jedis.ltrim(key, start, end); } catch (JedisException e) { handleJedisException(e); throw e; } finally { if (jedis != null) { jedis.close(); } } } /** * 算是删除吧,只保留start与end之间的记录 * * @param key * @param start 记录的开始位置(0表示第一条记录) * @param end 记录的结束位置(如果为-1则表示最后一个,-2,-3以此类推) * @return 执行状态码 */ public String ltrim(String key, int start, int end) { return ltrim(SafeEncoder.encode(key), start, end); } }
更多实例参考:http://www.cnblogs.com/liuling/p/2014-4-19-04.html
- Redis使用简明教程
- Redis简明教程-要点
- bcg 简明使用教程
- Git使用简明教程
- map使用简明教程
- Git 简明使用教程
- 事务使用简明教程
- Markdown简明使用教程
- Socket使用简明教程
- vim使用简明教程
- GDB使用简明教程
- git使用简明教程
- 简明adb使用教程
- git 简明使用教程
- git使用简明教程
- Git 简明使用教程
- jquery 使用简明教程
- CocoaPods使用简明教程
- 【typical】【JZOJ 5296】Sequence
- Java多线程(二)认识Java里面的Thread
- PAT 1031 查验身份证
- 我们为什么要做一名系统管理员?
- C语言入门第七篇,强制类型转换和ASCll编码
- Redis使用简明教程
- poj 3007
- 二叉树:已知前序&&中序或中序&&后序构造树
- Codeforces Round #387 (Div. 2) A. Display Size
- HDU 2544 最短路
- 浅谈HTML中的行块标签
- java每日一练
- Overfitting
- HIVE学习笔记