使用Jedis操作redis 缓存

Posted ngulc

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用Jedis操作redis 缓存相关的知识,希望对你有一定的参考价值。

  Redis是一个开源的Key-Value数据缓存,和Memcached类似。

  Redis多种类型的value,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。

  Jedis 是 Redis 官方首选的 Java 客户端开发包。

  1 //连接redis ,redis的默认端口是6379
  2 
  3 Jedis  jedis = new Jedis ("localhost",6379); 
  4 
  5 
  6 
  7 //验证密码,如果没有设置密码这段代码省略
  8 
  9 jedis.auth("password"); 
 10 
 11 
 12 
 13 jedis.connect();//连接
 14 
 15 jedis.disconnect();//断开连接
 16 
 17 
 18 
 19 Set<String> keys = jedis.keys("*"); //列出所有的key
 20 
 21 Set<String> keys = jedis.keys("key"); //查找特定的key
 22 
 23 
 24 
 25 //移除给定的一个或多个key,如果key不存在,则忽略该命令. 
 26 
 27 jedis.del("key1");
 28 
 29 jedis.del("key1","key2","key3","key4","key5");
 30 
 31 
 32 
 33 //移除给定key的生存时间(设置这个key永不过期)
 34 jedis.persist("key1"); 
 35 
 36 //检查给定key是否存在
 37 jedis.exists("key1"); 
 38 
 39 //将key改名为newkey,当key和newkey相同或者key不存在时,返回一个错误
 40 jedis.rename("key1", "key2");
 41 
 42 //返回key所储存的值的类型。 
 43 //none(key不存在),string(字符串),list(列表),set(集合),zset(有序集),hash(哈希表) 
 44 jedis.type("key1");
 45 
 46 //设置key生存时间,当key过期时,它会被自动删除。 
 47 jedis.expire("key1", 5);//5秒过期 
 48  
 49 
 50 
 51 //字符串值value关联到key。 
 52 jedis.set("key1", "value1"); 
 53 
 54 //将值value关联到key,并将key的生存时间设为seconds(秒)。 
 55 jedis.setex("foo", 5, "haha"); 
 56 
 57 //清空所有的key
 58 jedis.flushAll();
 59 
 60 //返回key的个数 
 61 jedis.dbSize();
 62 
 63 //哈希表key中的域field的值设为value。 
 64 jedis.hset("key1", "field1", "field1-value"); 
 65 jedis.hset("key1", "field2", "field2-value"); 
 66 
 67 Map map = new HashMap(); 
 68 map.put("field1", "field1-value"); 
 69 map.put("field2", "field2-value"); 
 70 jedis.hmset("key1", map); 
 71 
 72 
 73 //返回哈希表key中给定域field的值 
 74 jedis.hget("key1", "field1");
 75 
 76 //返回哈希表key中给定域field的值(多个)
 77 List list = jedis.hmget("key1","field1","field2"); 
 78 for(int i=0;i<list.size();i++){ 
 79    System.out.println(list.get(i)); 
 80 } 
 81 
 82 //返回哈希表key中所有域和值
 83 Map<String,String> map = jedis.hgetAll("key1"); 
 84 for(Map.Entry entry: map.entrySet()) { 
 85    System.out.print(entry.getKey() + ":" + entry.getValue() + "\t"); 
 86 } 
 87 
 88 //删除哈希表key中的一个或多个指定域
 89 jedis.hdel("key1", "field1");
 90 jedis.hdel("key1", "field1","field2");
 91 
 92 //查看哈希表key中,给定域field是否存在。 
 93 jedis.hexists("key1", "field1");
 94 
 95 //返回哈希表key中的所有域
 96 jedis.hkeys("key1");
 97 
 98 //返回哈希表key中的所有值
 99 jedis.hvals("key1");
100 
101 
102 
103 //将值value插入到列表key的表头。 
104 jedis.lpush("key1", "value1-0"); 
105 jedis.lpush("key1", "value1-1"); 
106 jedis.lpush("key1", "value1-2"); 
107 
108 //返回列表key中指定区间内的元素,区间以偏移量start和stop指定.
109 //下标(index)参数start和stop从0开始;
110 //负数下标代表从后开始(-1表示列表的最后一个元素,-2表示列表的倒数第二个元素,以此类推)
111 List list = jedis.lrange("key1", 0, -1);//stop下标也在取值范围内(闭区间)
112 for(int i=0;i<list.size();i++){ 
113    System.out.println(list.get(i)); 
114 } 
115 
116 //返回列表key的长度。 
117 jedis.llen("key1")
118 
119 
120 
121 //将member元素加入到集合key当中。 
122 jedis.sadd("key1", "value0"); 
123 jedis.sadd("key1", "value1"); 
124 
125 //移除集合中的member元素。 
126 jedis.srem("key1", "value1"); 
127 
128 //返回集合key中的所有成员。 
129 Set set = jedis.smembers("key1"); 
130 
131 //判断元素是否是集合key的成员
132 jedis.sismember("key1", "value2")); 
133 
134 //返回集合key的元素的数量
135 jedis.scard("key1");
136  
137 //返回一个集合的全部成员,该集合是所有给定集合的交集
138 jedis.sinter("key1","key2")
139  
140 //返回一个集合的全部成员,该集合是所有给定集合的并集
141 jedis.sunion("key1","key2")
142 
143 //返回一个集合的全部成员,该集合是所有给定集合的差集
144 jedis.sdiff("key1","key2");

 

以上是关于使用Jedis操作redis 缓存的主要内容,如果未能解决你的问题,请参考以下文章

RedisPool类使用Jedis操作Redis

jedis连接redis

Java操作Redis之Jedis用法详解

redis缓存怎么结合java使用

NoSQL数据库之Redis数据操作持久化Jedis缓存处理的详解

Jedis连接池对Redis数据操作