开发者

在Java中以及Spring环境下操作Redis的过程

开发者 https://www.devze.com 2025-03-15 15:03 出处:网络 作者: 呼啦啦啦啦啦啦啦啦
目录Java环境下:1.创建maven 项目2.导入依赖3.配置端口转发一.基本命令:Spring环境:Java环境下:
目录
  • Java环境下:
    • 1.创建maven 项目
    • 2.导入依赖
    • 3.配置端口转发
  • 一.基本命令:
    • Spring环境:

      Java环境下:

      1.创建maven 项目

      2.导入依赖

      <!-- Redis -->
      		<dependency>
      			<groupId>redis.clients</groupId>
      			<artifactId>jedis</artifactId>
      			<version>4.3.2</version>
      		</dependency>

      此处使用的是Jedis(提供的api和redis命令高度一致)

      3.配置端口转发

      防止Redis的端口被黑客攻击     将云服务器的redis端口映射到本地主机中

      在xshell中配置:

      在Java中以及Spring环境下操作Redis的过程

       此时, 访问本地的 8888, 就相当于访问对应服务器的 6379

      在Java中以及Spring环境下操作Redis的过程

      此时连接成功

      一.基本命令:

          public static void test(Jedis jedis) {
              System.out.println("set 和 get 使用");
              //清空数据库
              jedis.flushAll();
              jedis.set("key","k1");
              jedis.set("key2","k2");
              jedis.set("key3","k3");
              String key = jedis.get("key");
              String key2 = jedis.get("key2");
              String key3 = jedis.get("key3");
              System.out.println("key: " + key);
              System.out.println("key2: " + key2);
              System.out.println("key3: " + key3);
              System.out.println("exists 和 del 使用");
              boolean result = jedis.exists("key");
              System.out.println("result:" + result);
              result = jedis.exists("key1111");
              System.out.println("result:" + result);
              long del = jedis.del("key", "key2");
              result = jedis.exists("key");
              System.out.println("result:" + result);
              System.out.println("keys 使用");
              jedis.set("key","k1");
              jedis.set("key2","k2");
              Set<String> keys = jedis.keys("*");
              System.out.println("keys: " + keys);
              System.out.println("expire 和 ttl 使用");
              jedis.set("key4","k4");
              jedis.expire("key4",10);
              //休眠5s
              try {
                  Thread.sleep(5000);
              } catch (InterruptedException e) {
                  throw new RuntimeException(e);
              }
              long ttl = jedis.ttl("key4");
              System.out.println("ttl: " + ttl );
              System.out.println("type 使用");
              jedis.flushAll();
              jedis.set("String", "1");
              St编程客栈ring type = jedis.type("String");
              System.out.println("type: "+type);
              jedis.lpush("list","111","222","333");
              type = jedis.type("list");
              System.out.println("type: "+type);
              jedis.sadd("set","a","b","c");
              type = jedis.type("set");
              System.out.println("type: "+type);
              jedis.zadd("zset",1.0,"zhangsan");
              type = jedis.type("zset");
              System.out.println("type: "+type);
              jedis.hset("hash","f1 ","v1");
              type = jedis.type("hash");
              System.out.println("type: "+type);
          }

      在Java中以及Spring环境下操作Redis的过程

       String :

          public static void test(Jedis jedis) {
              //清空数据库
              jedis.flushAll();
              System.out.println("mset 和 mget 使用");
              jedis.mset("k1","111","k2","222","k3","333");
              List<String> mget = jedis.mget("k1", "k2", "k3","k4");
              System.out.println("mget: " +mget);
              System.out.println("getrange 和 setrange 使用");
              jedis.set("k4","abcdefgh");
              String k4 = jedis.getrange("k4", 0, 4);
              System.out.println("result: " +k4);
              jedis.setrange("k4",0,"eeee");
              System.out.println("k4: " +jedis.get("k4"));
              System.out.println("append 使用");
              jedis.append("k4","aaaaaa");
              System.out.println("k4: " + jedis.get("k4"));
              System.out.println("incr 和 decr 使用");
              jedis.set("k5","111");
              System.out.println( "k5: " + jedis.incr("k5"));
              System.out.println( "k5: " + jedis.decr("k5"));
          }

       

      在Java中以及Spring环境下操作Redis的过程

      list使用:

          public static void  test(Jedis jedis) {
              jedis.flushAll();
              System.out.println("lpush 和 lrange 使用");
              jedis.lpush("key","1","2","3","4","5");
              System.out.println("key:" + jedis.lrange("key",0,-1));
              System.out.println("rpuhs ,rpop, lpop 使用 ");
              jedis.rpush("key2","1","2","3","4","5");
         android     System.out.println("key2 :" + jedis.lrange("key2",0,-1));
              System.out.println("lpop key2:" + jedis.lpop("key2"));
              System.out.println("rpop key2:" + jedis.rpop("key2"));
              System.out.println("llen 使用");
              System.out.println("len key2: " + jedis.llen("key2"));
          }

      在Java中以及Spring环境下操作Redis的过程

      hash的使用:

          private static void test(Jedis jedis) {
              jedis.flushAll();
              System.out.println("hset 和 hget 使用");
              HashMap<String,String> hash = new HashMap<>();
              hash.put("f2","v2");
              hash.put("f3","v3");
         编程     hash.put("f4","v4");
              jedis.hset("key",hash);
              jedis.hset("key","f1","v1");
              System.out.println("key f1: " +jedis.hget("key", "f1"));
              System.out.println("key f5: " +jedis.hget("key", "f5"));
              System.out.println("hexists 使用");
              Boolean result = jedis.hexists("key","f1");
              System.out.println("key f1 result: " + result);
              result = jedis.hexists("key","f5");
              System.out.println("key f5 result: " + result);
              System.out.println("hkeys 和 hvals 使用");
              Set<String> hkeys = jedis.hkeys("key");
              System.out.println("hkeys: " + hkeys);
              List<String> hvals = jedis.hvals("key");
              System.out.println("编程客栈hvals: " +hvals);
              System.out.println("hdel 使用");
              jedis.hdel("key","f1");
              result = jedis.hexists("key","f1");
              System.out.println("key f1 result: " + result);
              System.out.println("hmset 和 hmget 使用");
              List<String> hmget = jedis.hmget("key", "f1", "f2", "f3");
              System.out.println("hmget key: " + hmget);
          }

      在Java中以及Spring环境下操作Redis的过程

      set的使用:

          public static void test(Jedis jedis) {
              jedis.flushAll();
              System.out.println("sadd 和 smembers 使用");
              jedis.sadd("key","a","b","c","d");
              Set<String> smembers = jedis.smembers("key");
              System.out.println("key: " +smembers);
              System.out.println("sismember , scard , spop  使用");
              boolean result = jedis.sismember("key", "a");
              System.out.println("result: " + result);
              long len  = jedis.scard("key");
              System.out.println("key len: " +len);
              jedis.spop("key");
              System.out.println("key len: " +jedis.scard("key"));
              System.out.println("sinter 和 sinterstore");
              jedis.sadd("key2","1","2","3","4","5");
              jedis.sadd("key3","3","4","5","6","7");
              System.out.println("[key2 key3]sinter: "+ jedis.sinter("key2","key3"));
              long sinterstore = jedis.sinterstore("key4", "key2", "key3");
              System.out.println("sinterstore: " + sinterstore);
              System.out.println("key4: " + jedis.smembers("key4"));
          }

      在Java中以及Spring环境下操作Redis的过程

      zset的使用:

          public static void test(Jedis jedis) {
              jedis.flushAll();
              System.编程out.println("zadd 和 zrange 使用");
              jedis.zadd("key",10.0,"zhangsan");
              Map<String ,Double> hash = new HashMap<>();
              hash.put("lisi",20.0);
              hash.put("wangwu",30.0);
              jedis.zadd("key",hash);
              List<String> members = jedis.zrange("key", 0, -1);
              System.out.println("members: "+members);
              List<Tuple> key = jedis.zrangeWithScores("key", 0, -1);
              System.out.println("key: " + key);
              System.out.println("zcard , zscore 使用");
              long len = jedis.zcard("key");
              System.out.println("len key: " +len);
              Double score  =  jedis.zscore("key","zhangsan");
              System.out.println("score: " + score);
              System.out.println("zrem , zrank 使用");
              Long zrank = jedis.zrank("key", "lisi");
              System.out.println("lisi rank: " + zrank);
              jedis.zrem("key","zhangsan");
              System.out.println("lisi rank: " + jedis.zrank("key", "lisi"));
          }

       

      在Java中以及Spring环境下操作Redis的过程

      都是一些基本操作,跟在redis操作基本一致,

      Spring环境:

      创建项目时勾选即可

      在Java中以及Spring环境下操作Redis的过程

      在Java中以及Spring环境下操作Redis的过程

      通过注入的方法拿到StringRedisTemplate操作Redis 相当于刚才的Jedis

      在Java中以及Spring环境下操作Redis的过程

       将操作Redis的方法分成几个类别,好进一步更好的组织

      在Java中以及Spring环境下操作Redis的过程

      在Java中以及Spring环境下操作Redis的过程

      大体命令基本一致 

      到此这篇关于在Java中以及Spring环境下操作Redis的文章就介绍到这了,更多相关java中操作redis内容请搜索编程客栈(www.devze.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程客栈(www.devze.com)!

      0

      精彩评论

      暂无评论...
      验证码 换一张
      取 消

      关注公众号