• Spring Data Redis使用方式


    1.导入Spring Data Redis的maven坐标

    pom.xml


        org.springframework.boot
        spring-boot-starter-data-redis

    2. 配置Redis数据源

    2.1application.yml文件 

      datasource:
        druid:
          driver-class-name: ${sky.datasource.driver-class-name}
          url: jdbc:mysql://${sky.datasource.host}:${sky.datasource.port}/${sky.datasource.database}?serverTimezone=Asia/Shanghai&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&useSSL=false&allowPublicKeyRetrieval=true
          username: ${sky.datasource.username}
          password: ${sky.datasource.password}
    #      redis数据连接
      redis:
        host: ${sky.redis.host}
        port: ${sky.redis.port}
        password: ${sky.redis.password}
        database: ${sky.redis.database} 

    2.2application-dev.yml文件 

     

    sky:
      datasource:
        driver-class-name: com.mysql.cj.jdbc.Driver
        host: localhost
        port: 3306
        database: sky_take_out
        username: root
        password: 123456
    
      redis:
        host: localhost
        port: 6379
        password: 123456
        database: 10

    3. 编写配置类,创建RedisTemplate对象

    1. package com.sky.config;
    2. import lombok.extern.slf4j.Slf4j;
    3. import org.springframework.context.annotation.Bean;
    4. import org.springframework.context.annotation.Configuration;
    5. import org.springframework.data.redis.connection.RedisConnectionFactory;
    6. import org.springframework.data.redis.core.RedisTemplate;
    7. import org.springframework.data.redis.serializer.StringRedisSerializer;
    8. @Configuration
    9. @Slf4j
    10. public class RedisConfiguration {
    11. @Bean
    12. public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory) {
    13. log.info("开始创建redis");
    14. RedisTemplate redisTemplate = new RedisTemplate();
    15. // 设置redis的连接工厂对象
    16. redisTemplate.setConnectionFactory(redisConnectionFactory);
    17. // 设置redis key的序列化器
    18. redisTemplate.setKeySerializer(new StringRedisSerializer());
    19. return redisTemplate;
    20. }
    21. }

    4.通过RedisTemplate对象操作Redis

    说明:编写测试类

    1. package com.sky.test;
    2. import org.junit.jupiter.api.Test;
    3. import org.springframework.beans.factory.annotation.Autowired;
    4. import org.springframework.boot.test.context.SpringBootTest;
    5. import org.springframework.data.redis.core.*;
    6. import java.sql.Time;
    7. import java.util.concurrent.TimeUnit;
    8. @SpringBootTest
    9. public class SpringDataRedisTest {
    10. @Autowired
    11. private RedisTemplate redisTemplate;
    12. @Test
    13. public void testRedisTemplate() {
    14. System.out.println(redisTemplate);
    15. ValueOperations valueOperations = redisTemplate.opsForValue();
    16. HashOperations hashOperations = redisTemplate.opsForHash();
    17. ListOperations listOperations = redisTemplate.opsForList();
    18. SetOperations setOperations = redisTemplate.opsForSet();
    19. }
    20. /*操作字符串类型的数据
    21. *
    22. * */
    23. @Test
    24. public void testString() {
    25. //set get setex setnx
    26. redisTemplate.opsForValue().set("city", "北京");
    27. String city = (String) redisTemplate.opsForValue().get("city");
    28. System.out.println(city);
    29. redisTemplate.opsForValue().set("code","1234",3, TimeUnit.MINUTES);
    30. // setnx
    31. redisTemplate.opsForValue().setIfAbsent("lock","1");
    32. redisTemplate.opsForValue().setIfAbsent("lock","2");
    33. }
    34. }

    5.结果

     

  • 相关阅读:
    一周侃 | 周末随笔及推荐
    todo-list案例--全局事件总线
    前端文件流下载填坑之旅
    VINS学习04———Omni教程
    最新百度专用站群seo官网程序源码二级泛程序
    Himall商城-公共方法
    计算平均分数并将其分配给对象
    linux查看各个目录占用磁盘的大小&清理nohup.out日志
    【LaTex】LaTex的下载与安装(超详细、超简洁)
    Springboot整合jdbc和Mybatis
  • 原文地址:https://blog.csdn.net/m0_62785037/article/details/133712418