14.Redis之JAVASpring客户端

2024-05-30 1165阅读

1.引入依赖

14.Redis之JAVASpring客户端

此时就会引入操作 redis 的依赖了~~ 

2.yml配置

spring:
  redis:
    host: 127.0.0.1
    port: 8888

3.准备

14.Redis之JAVASpring客户端

  • 前面使用 jedis,是通过 Jedis 对象里的各种方法来操作 redis 的.
  • 此处Spring 中则是通过 StringRedisTemplate 来操作 redis .
  • 最原始提供的类是 RedisTemplate
  • StringRedisTemplate 是 RedisTemplate 的子类, 专门用来处理 文本数据的
  • 这个类提供的方法,相比于之前的 Jedis 中的各种方法,还是存在较大的差异的!!
  • 14.Redis之JAVASpring客户端
  • 14.Redis之JAVASpring客户端

    4.代码 

    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.data.redis.connection.RedisConnection;
    import org.springframework.data.redis.core.StringRedisTemplate;
    import org.springframework.data.redis.core.ZSetOperations;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.ResponseBody;
    import org.springframework.web.bind.annotation.RestController;
    import java.util.Set;
    // 后续 redis 测试的各种方法, 都通过这个 Controller 提供的 http 接口来触发.
    @RestController
    public class MyController {
        @Autowired
        private StringRedisTemplate redisTemplate;
        @GetMapping("/testString")
        @ResponseBody
        public String testString() {
            redisTemplate.execute((RedisConnection connection) -> {
                // execute 要求回调方法中必须写 return 语句. 返回个东西.
                // 这个回调返回的对象, 就会作为 execute 本身的返回值.
                connection.flushAll();
                return null;
            });
            redisTemplate.opsForValue().set("key", "111");
            redisTemplate.opsForValue().set("key2", "222");
            redisTemplate.opsForValue().set("key3", "333");
            String value = redisTemplate.opsForValue().get("key");
            System.out.println("value: " + value);
            return "OK";
        }
        @GetMapping("/testList")
        @ResponseBody
        public String testList() {
            // 先清除之前的数据.
            redisTemplate.execute((RedisConnection connection) -> {
                // execute 要求回调方法中必须写 return 语句. 返回个东西.
                // 这个回调返回的对象, 就会作为 execute 本身的返回值.
                connection.flushAll();
                return null;
            });
            redisTemplate.opsForList().leftPush("key", "111");
            redisTemplate.opsForList().leftPush("key", "222");
            redisTemplate.opsForList().leftPush("key", "333");
            String value = redisTemplate.opsForList().rightPop("key");
            System.out.println("value: " + value);
            value = redisTemplate.opsForList().rightPop("key");
            System.out.println("value: " + value);
            value = redisTemplate.opsForList().rightPop("key");
            System.out.println("value: " + value);
            return "OK";
        }
        @GetMapping("/testSet")
        @ResponseBody
        public String testSet() {
            redisTemplate.execute((RedisConnection connection) -> {
                connection.flushAll();
                return null;
            });
            redisTemplate.opsForSet().add("key", "111", "222", "333");
            Set result = redisTemplate.opsForSet().members("key");
            System.out.println("result: " + result);
            Boolean exists = redisTemplate.opsForSet().isMember("key", "111");
            System.out.println("exists: " + exists);
            Long count = redisTemplate.opsForSet().size("key");
            System.out.println("count: " + count);
            redisTemplate.opsForSet().remove("key", "111", "222");
            result = redisTemplate.opsForSet().members("key");
            System.out.println("result: " + result);
            return "OK";
        }
        @GetMapping("/testHash")
        @ResponseBody
        public String testHash() {
            redisTemplate.execute((RedisConnection connection) -> {
                connection.flushAll();
                return null;
            });
            redisTemplate.opsForHash().put("key", "f1", "111");
            redisTemplate.opsForHash().put("key", "f2", "222");
            redisTemplate.opsForHash().put("key", "f3", "333");
            String value = (String) redisTemplate.opsForHash().get("key", "f1");
            System.out.println("value: " + value);
            Boolean exists = redisTemplate.opsForHash().hasKey("key", "f1");
            System.out.println("exists: " + exists);
            redisTemplate.opsForHash().delete("key", "f1", "f2");
            Long size = redisTemplate.opsForHash().size("key");
            System.out.println("size: " + size);
            return "OK";
        }
        @GetMapping("/testZSet")
        @ResponseBody
        public String testZSet() {
            redisTemplate.execute((RedisConnection connection) -> {
                connection.flushAll();
                return null;
            });
            redisTemplate.opsForZSet().add("key", "zhangsan", 10);
            redisTemplate.opsForZSet().add("key", "lisi", 20);
            redisTemplate.opsForZSet().add("key", "wangwu", 30);
            Set members = redisTemplate.opsForZSet().range("key", 0, -1);
            System.out.println("members: " + members);
            Set membersWithScore = redisTemplate.opsForZSet().rangeWithScores("key", 0, -1);
            System.out.println("membersWithScore: " + membersWithScore);
            Double score = redisTemplate.opsForZSet().score("key", "zhangsan");
            System.out.println("score: " + score);
            redisTemplate.opsForZSet().remove("key", "zhangsan");
            Long size = redisTemplate.opsForZSet().size("key");
            System.out.println("size: " + size);
            Long rank = redisTemplate.opsForZSet().rank("key", "lisi");
            System.out.println("rank: " + rank);
            return "OK";
        }
    }
    

    5.测试

    14.Redis之JAVASpring客户端

    Spring Data Redis 中文文档 (springdoc.cn)

VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]