打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
使用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");
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
Redis和DelayQueue设计具有过期时间的缓存
用kafka和redis实现一个推送消息功能
深入浅出分布式缓存的通用方法
使用Redis bitmap进行活跃用户统计
5)深度解密 Redis 的哈希(Hash)
Redis安装和实际应用
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服