中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringBoot集成Redis如何使用RedisRepositories

發布時間:2022-03-15 14:47:40 來源:億速云 閱讀:379 作者:iii 欄目:開發技術

這篇“SpringBoot集成Redis如何使用RedisRepositories”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“SpringBoot集成Redis如何使用RedisRepositories”文章吧。

    SpringBoot集成Redis

     1.添加redis依賴

    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-data-redis</artifactId>
    </dependency>
    <dependency>
      <groupId>org.apache.commons</groupId>
      <artifactId>commons-pool2</artifactId>
    </dependency>

    2.在application.properties中添加redis配置信息

    spring.redis.host=127.0.0.1
    # Redis服務器連接端口
    spring.redis.port=6379
    # Redis服務器連接密碼(默認為空)
    spring.redis.password=
    # 連接池最大連接數(使用負值表示沒有限制)
    spring.redis.lettuce.pool.max-active=8
    # 連接池最大阻塞等待時間(使用負值表示沒有限制)
    spring.redis.lettuce.pool.max-wait=-1
    # 連接池中的最大空閑連接
    spring.redis.lettuce.pool.max-idle=8
    # 連接池中的最小空閑連接
    spring.redis.lettuce.pool.min-idle=0
    # 連接超時時間(毫秒)
    spring.redis.timeout=30000

    3.SpringBoot啟動類中添加注解配置

    @EnableCaching
    @EnableRedisRepositories
    //注解開啟使用RedisRepositories
    //CRUD操作將會操作redis中的數據
    @SpringBootApplication
    public class RedisApplication {
     
        public static void main(String[] args) {
            SpringApplication.run(RedisApplication.class, args);
        } 
    }

    4.創建實體類Entity

    @Data
    @RedisHash("user")
    //RedisHash非常重要
    //user表示在redis中新建user集合
    //之后所有的UserEntity的保存操作全部會保存在user這個集合中
    //保存時Key的格式為——user:id
    public class UserEntity{
        @Id
        private Long id; 
        private String name; 
        private Integer age; 
        private Date createTime = new Date();
    }

    5.創建Dao層&mdash;&mdash;數據操作層

    @Repository
    public interface UserDao extends CrudRepository<UserEntity,Long> {
    }

    6.創建Service層&mdash;&mdash;服務層

    @Service
    public class UserService {
     
        @Autowired
        private UserDao userDao;
     
    //因為使用了RedisRepositories,所以簡單的crud將不用使用RedisTemplate
    //    @Autowired
    //    private RedisTemplate redisTemplate; 
     
        /**
         * 按user:id的方式存入redis
         * @param user
         */
        public void save(UserEntity user){
            //redisTemplate.opsForValue().set(new Random().nextDouble() + "",user); 
            userDao.save(user); 
        }
     
        /**
         * 根據key從redis中查找對應value
         * @param id
         * @return
         */
        public UserEntity findOne(Long id){ 
            //UserEntity user = (UserEntity) redisTemplate.opsForValue().get(key); 
            UserEntity user = userDao.findById(id).get(); 
            return user;
        }
    }

    7.創建Controller層&mdash;&mdash;控制層

    @RestController
    @RequestMapping("user")
    public class UserController {
     
        @Autowired
        private UserService userService;
     
        /**
         * 保存到redis中
         * @return
         */
        @GetMapping("save")
        public String save(){
     
            UserEntity user = new UserEntity(); 
            user.setName(String.valueOf(new Random().nextInt(100000))); 
            user.setAge(new Random().nextInt(100000)); 
            userService.save(user); 
            System.out.println(user.toString()); 
            return "success";
        }
     
        /**
         * 根據key從redis中查找value
         * @param id
         * @return
         */
        @GetMapping("find/{id}")
        public String find(@PathVariable Long id){
           UserEntity user = userService.findOne(id);
     
            System.out.println(user);
            return "success";
        }
    }

    8.redis配置類

    @Configuration
    public class RedisConfig {
     
        @Bean
        public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
            RedisTemplate<String, Object> template = new RedisTemplate<String, Object>();
            template.setConnectionFactory(factory);
            Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
            ObjectMapper om = new ObjectMapper();
            om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
            om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
            jackson2JsonRedisSerializer.setObjectMapper(om);
            StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
            // key采用String的序列化方式
            template.setKeySerializer(stringRedisSerializer);
            // hash的key也采用String的序列化方式
            template.setHashKeySerializer(stringRedisSerializer);
            // value序列化方式采用jackson
            template.setValueSerializer(jackson2JsonRedisSerializer);
            // hash的value序列化方式采用jackson
            template.setHashValueSerializer(jackson2JsonRedisSerializer);
            template.afterPropertiesSet();
            return template;
        }
    }

    Redis中的結構為

    SpringBoot集成Redis如何使用RedisRepositories

    redis封裝工具類

    @Component
    public class RedisUtils {
     
    	@Autowired
    	private RedisTemplate<String, Object> redisTemplate;
     
    	// =============================common============================
     
    	/**
    	 * 指定緩存失效時間
    	 *
    	 * @param key  鍵
    	 * @param time 時間(秒)
    	 * @return
    	 */
    	public boolean expire(String key, long time) {
    		try {
    			if (time > 0) {
    				redisTemplate.expire(key, time, TimeUnit.SECONDS);
    			}
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 根據key 獲取過期時間
    	 *
    	 * @param key 鍵 不能為null
    	 * @return 時間(秒) 返回0代表為永久有效
    	 */
    	public long getExpire(String key) {
    		return redisTemplate.getExpire(key, TimeUnit.SECONDS);
    	}
     
    	/**
    	 * 判斷key是否存在
    	 *
    	 * @param key 鍵
    	 * @return true 存在 false不存在
    	 */
    	public boolean hasKey(String key) {
    		try {
    			return redisTemplate.hasKey(key);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 刪除緩存
    	 *
    	 * @param key 可以傳一個值 或多個
    	 */
    	@SuppressWarnings("unchecked")
    	public void del(String... key) {
    		if (key != null && key.length > 0) {
    			if (key.length == 1) {
    				redisTemplate.delete(key[0]);
    			} else {
    				redisTemplate.delete(CollectionUtils.arrayToList(key));
    			}
    		}
    	}
    	// ============================String=============================
     
    	/**
    	 * 普通緩存獲取
    	 *
    	 * @param key 鍵
    	 * @return 值
    	 */
    	public  Object get(String key) {
    		return key == null ? null : redisTemplate.opsForValue().get(key);
    	}
     
    	/**
    	 * 普通緩存放入
    	 *
    	 * @param key   鍵
    	 * @param value 值
    	 * @return true成功 false失敗
    	 */
    	public boolean set(String key, Object value) {
    		try {
    			redisTemplate.opsForValue().set(key, value);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 普通緩存放入并設置時間
    	 *
    	 * @param key   鍵
    	 * @param value 值
    	 * @param time  時間(秒) time要大于0 如果time小于等于0 將設置無限期
    	 * @return true成功 false 失敗
    	 */
    	public boolean set(String key, Object value, long time) {
    		try {
    			if (time > 0) {
    				redisTemplate.opsForValue().set(key, value, time, TimeUnit.SECONDS);
    			} else {
    				set(key, value);
    			}
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 遞增
    	 *
    	 * @param key   鍵
    	 * @param delta 要增加幾(大于0)
    	 * @return
    	 */
    	public long incr(String key, long delta) {
    		if (delta < 0) {
    			throw new RuntimeException("遞增因子必須大于0");
    		}
    		return redisTemplate.opsForValue().increment(key, delta);
    	}
     
    	/**
    	 * 遞減
    	 *
    	 * @param key   鍵
    	 * @param delta 要減少幾(小于0)
    	 * @return
    	 */
    	public long decr(String key, long delta) {
    		if (delta < 0) {
    			throw new RuntimeException("遞減因子必須大于0");
    		}
    		return redisTemplate.opsForValue().increment(key, -delta);
    	}
    	// ================================Map=================================
     
    	/**
    	 * HashGet
    	 *
    	 * @param key  鍵 不能為null
    	 * @param item 項 不能為null
    	 * @return 值
    	 */
    	public Object hget(String key, String item) {
    		return redisTemplate.opsForHash().get(key, item);
    	}
     
    	/**
    	 * 獲取hashKey對應的所有鍵值
    	 *
    	 * @param key 鍵
    	 * @return 對應的多個鍵值
    	 */
    	public Map<Object, Object> hmget(String key) {
    		return redisTemplate.opsForHash().entries(key);
    	}
     
    	/**
    	 * HashSet
    	 *
    	 * @param key 鍵
    	 * @param map 對應多個鍵值
    	 * @return true 成功 false 失敗
    	 */
    	public boolean hmset(String key, Map<String, Object> map) {
    		try {
    			redisTemplate.opsForHash().putAll(key, map);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * HashSet 并設置時間
    	 *
    	 * @param key  鍵
    	 * @param map  對應多個鍵值
    	 * @param time 時間(秒)
    	 * @return true成功 false失敗
    	 */
    	public boolean hmset(String key, Map<String, Object> map, long time) {
    		try {
    			redisTemplate.opsForHash().putAll(key, map);
    			if (time > 0) {
    				expire(key, time);
    			}
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 向一張hash表中放入數據,如果不存在將創建
    	 *
    	 * @param key   鍵
    	 * @param item  項
    	 * @param value 值
    	 * @return true 成功 false失敗
    	 */
    	public boolean hset(String key, String item, Object value) {
    		try {
    			redisTemplate.opsForHash().put(key, item, value);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 向一張hash表中放入數據,如果不存在將創建
    	 *
    	 * @param key   鍵
    	 * @param item  項
    	 * @param value 值
    	 * @param time  時間(秒) 注意:如果已存在的hash表有時間,這里將會替換原有的時間
    	 * @return true 成功 false失敗
    	 */
    	public boolean hset(String key, String item, Object value, long time) {
    		try {
    			redisTemplate.opsForHash().put(key, item, value);
    			if (time > 0) {
    				expire(key, time);
    			}
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 刪除hash表中的值
    	 *
    	 * @param key  鍵 不能為null
    	 * @param item 項 可以使多個 不能為null
    	 */
    	public void hdel(String key, Object... item) {
    		redisTemplate.opsForHash().delete(key, item);
    	}
     
    	/**
    	 * 判斷hash表中是否有該項的值
    	 *
    	 * @param key  鍵 不能為null
    	 * @param item 項 不能為null
    	 * @return true 存在 false不存在
    	 */
    	public boolean hHasKey(String key, String item) {
    		return redisTemplate.opsForHash().hasKey(key, item);
    	}
     
    	/**
    	 * hash遞增 如果不存在,就會創建一個 并把新增后的值返回
    	 *
    	 * @param key  鍵
    	 * @param item 項
    	 * @param by   要增加幾(大于0)
    	 * @return
    	 */
    	public double hincr(String key, String item, double by) {
    		return redisTemplate.opsForHash().increment(key, item, by);
    	}
     
    	/**
    	 * hash遞減
    	 *
    	 * @param key  鍵
    	 * @param item 項
    	 * @param by   要減少記(小于0)
    	 * @return
    	 */
    	public double hdecr(String key, String item, double by) {
    		return redisTemplate.opsForHash().increment(key, item, -by);
    	}
    	// ============================set=============================
     
    	/**
    	 * 根據key獲取Set中的所有值
    	 *
    	 * @param key 鍵
    	 * @return
    	 */
    	public Set<Object> sGet(String key) {
    		try {
    			return redisTemplate.opsForSet().members(key);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return null;
    		}
    	}
     
    	/**
    	 * 根據value從一個set中查詢,是否存在
    	 *
    	 * @param key   鍵
    	 * @param value 值
    	 * @return true 存在 false不存在
    	 */
    	public boolean sHasKey(String key, Object value) {
    		try {
    			return redisTemplate.opsForSet().isMember(key, value);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 將數據放入set緩存
    	 *
    	 * @param key    鍵
    	 * @param values 值 可以是多個
    	 * @return 成功個數
    	 */
    	public long sSet(String key, Object... values) {
    		try {
    			return redisTemplate.opsForSet().add(key, values);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return 0;
    		}
    	}
     
    	/**
    	 * 將set數據放入緩存
    	 *
    	 * @param key    鍵
    	 * @param time   時間(秒)
    	 * @param values 值 可以是多個
    	 * @return 成功個數
    	 */
    	public long sSetAndTime(String key, long time, Object... values) {
    		try {
    			Long count = redisTemplate.opsForSet().add(key, values);
    			if (time > 0)
    				expire(key, time);
    			return count;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return 0;
    		}
    	}
     
    	/**
    	 * 獲取set緩存的長度
    	 *
    	 * @param key 鍵
    	 * @return
    	 */
    	public long sGetSetSize(String key) {
    		try {
    			return redisTemplate.opsForSet().size(key);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return 0;
    		}
    	}
     
    	/**
    	 * 移除值為value的
    	 *
    	 * @param key    鍵
    	 * @param values 值 可以是多個
    	 * @return 移除的個數
    	 */
    	public long setRemove(String key, Object... values) {
    		try {
    			Long count = redisTemplate.opsForSet().remove(key, values);
    			return count;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return 0;
    		}
    	}
    	// ===============================list=================================
     
    	/**
    	 * 獲取list緩存的內容
    	 *
    	 * @param key   鍵
    	 * @param start 開始
    	 * @param end   結束 0 到 -1代表所有值
    	 * @return
    	 */
    	public List<Object> lGet(String key, long start, long end) {
    		try {
    			return redisTemplate.opsForList().range(key, start, end);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return null;
    		}
    	}
     
    	/**
    	 * 獲取list緩存的長度
    	 *
    	 * @param key 鍵
    	 * @return
    	 */
    	public long lGetListSize(String key) {
    		try {
    			return redisTemplate.opsForList().size(key);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return 0;
    		}
    	}
     
    	/**
    	 * 通過索引 獲取list中的值
    	 *
    	 * @param key   鍵
    	 * @param index 索引 index>=0時, 0 表頭,1 第二個元素,依次類推;index<0時,-1,表尾,-2倒數第二個元素,依次類推
    	 * @return
    	 */
    	public Object lGetIndex(String key, long index) {
    		try {
    			return redisTemplate.opsForList().index(key, index);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return null;
    		}
    	}
     
    	/**
    	 * 將list放入緩存
    	 *
    	 * @param key   鍵
    	 * @param value 值
    	 * @return
    	 */
    	public boolean lSet(String key, Object value) {
    		try {
    			redisTemplate.opsForList().rightPush(key, value);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 將list放入緩存
    	 *
    	 * @param key   鍵
    	 * @param value 值
    	 * @param time  時間(秒)
    	 * @return
    	 */
    	public boolean lSet(String key, Object value, long time) {
    		try {
    			redisTemplate.opsForList().rightPush(key, value);
    			if (time > 0)
    				expire(key, time);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 將list放入緩存
    	 *
    	 * @param key   鍵
    	 * @param value 值
    	 * @return
    	 */
    	public boolean lSet(String key, List<Object> value) {
    		try {
    			redisTemplate.opsForList().rightPushAll(key, value);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 將list放入緩存
    	 *
    	 * @param key   鍵
    	 * @param value 值
    	 * @param time  時間(秒)
    	 * @return
    	 */
    	public boolean lSet(String key, List<Object> value, long time) {
    		try {
    			redisTemplate.opsForList().rightPushAll(key, value);
    			if (time > 0)
    				expire(key, time);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 根據索引修改list中的某條數據
    	 *
    	 * @param key   鍵
    	 * @param index 索引
    	 * @param value 值
    	 * @return
    	 */
    	public boolean lUpdateIndex(String key, long index, Object value) {
    		try {
    			redisTemplate.opsForList().set(key, index, value);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 移除N個值為value
    	 *
    	 * @param key   鍵
    	 * @param count 移除多少個
    	 * @param value 值
    	 * @return 移除的個數
    	 */
    	public long lRemove(String key, long count, Object value) {
    		try {
    			Long remove = redisTemplate.opsForList().remove(key, count, value);
    			return remove;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return 0;
    		}
    	}
    }

    以上就是關于“SpringBoot集成Redis如何使用RedisRepositories”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    涡阳县| 无棣县| 大同市| 繁峙县| 百色市| 西乡县| 房山区| 松江区| 外汇| 驻马店市| 公主岭市| 开远市| 吉首市| 东辽县| 遵义县| 朝阳市| 宜都市| 疏勒县| 漠河县| 香格里拉县| 鄢陵县| 平山县| 呼玛县| 萍乡市| 曲阜市| 昌平区| 宁陕县| 白银市| 石林| 江城| 仙桃市| 日照市| 阿巴嘎旗| 平乡县| 于田县| 綦江县| 诏安县| 洪洞县| 河南省| 四子王旗| 宣恩县|