redistemplate获取数据
时间: 2023-09-14 13:11:13 浏览: 109
redistemplate
4星 · 用户满意度95%
要RedisTemplate获取数据,首先需要在Spring容器中初始化配置类。该配置类主要用于设置key和value的序列化方式。通常情况下,key使用String的序列化方式,value使用JSON的序列化方式。配置类的示例如下:
@Configuration
public class RedisTemplateConfig {
@Bean
@Primary
public RedisTemplate<String, Object> redisCacheTemplate(LettuceConnectionFactory redisConnectionFactory){
RedisTemplate<String, Object> template = new RedisTemplate<>();
template.setConnectionFactory(redisConnectionFactory);
FastJsonRedisSerializer fastJsonRedisSerializer = new FastJsonRedisSerializer(Object.class);
template.setKeySerializer(new StringRedisSerializer()); // key的序列化方式为String
template.setHashKeySerializer(new StringRedisSerializer());
template.setValueSerializer(fastJsonRedisSerializer); // value的序列化方式为JSON
template.setHashValueSerializer(fastJsonRedisSerializer);
template.setDefaultSerializer(fastJsonRedisSerializer);
template.afterPropertiesSet();
return template;
}
}
接下来,在使用的地方通过@Autowired注入RedisTemplate即可:
@Autowired
private RedisTemplate<String, Object> redisTemplate;
通过RedisTemplate可以使用各种操作方法来获取数据。例如,若要获取set集合中的数据,可以使用redisTemplate.opsForSet()方法。通过members()方法可以直接获取该set集合中的所有数据。在打印输出时,你会发现如果插入了与之前重复的数据,set集合会自动去重。以下是一个示例:
public void getRedisSet(){
Set<Object> members = redisTemplate.opsForSet().members(RedisConstantKey.MY_REDIS_SET.key);
Iterator<Object> it = members.iterator();
while (it.hasNext()){
System.out.println(it.next());
}
}
输出结果为:bb cc aa [3<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [redisTemplate分别存取redis的string/list/set/zset/hash等数据类型](https://blog.csdn.net/u012809308/article/details/107141004)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]
阅读全文