redisTemplate.opsForValue().set数据跟本地redis数据不符
RedisTemplate 使用时传入数据与本地redis数据不符
·
当使用 RedisTemplate 时,直接使用泛型对redis进行赋值发现值与本地查询的值不同
借鉴于 Redis Template及4种序列化方式 - csjoz11 - 博客园
在使用rem可视化工具后发现,出现相同的乱码问题。
因此,如果是已经能够确定redis放入的数据时,可以提前确定redistemplate的类型如:StringRedisTemplate
如果在直接使用StringRedisTemplate 对redis 传入数据,并不会出现乱码或数据不符的问题。
@Autowired
private StringRedisTemplate redisTemplate;
@Test
void testString(){
//插入一条string类型数据
redisTemplate.opsForValue().set("name","zhangsan");
//读取一条string类型数据
Object name = redisTemplate.opsForValue().get("name");
System.out.println("name:"+name);
}
redis 的数据类型可以参考:
因此,如果能够提前确定好需要传入的类型,即可正确传入。
若是使用hash数据等其他数据时,需要自定义序列化如:
重新创建RedisTemplate 并定义序列化
@Configuration
public class RedisConfig {
@Bean
public RedisTemplate<Object,Object> getRedisTemplate(RedisConnectionFactory redisConnectionFactory){
RedisTemplate<Object,Object> redisTemplate = new RedisTemplate<>();
// 设置最外层key, 即key的序列化
redisTemplate.setKeySerializer(new StringRedisSerializer());
// 设置内层key, 即field的序列化
redisTemplate.setHashKeySerializer(new StringRedisSerializer());
// 设置内层val, 即value的序列化
redisTemplate.setHashValueSerializer(new StringRedisSerializer());
/*
*
* 使用 JSON 序列化方式(库是 Jackson ),序列化 VALUE 。
redisTemplate.setValueSerializer(RedisSerializer.json());
* */
redisTemplate.setConnectionFactory(redisConnectionFactory);
return redisTemplate;
}
}
接下来只需要 创建一个实例对象并注入spring容器内即可使用
@Autowired
private RedisConfig config;
@Test
void testSet(){
JedisConnectionFactory factory = new JedisConnectionFactory();
RedisTemplate<Object, Object> redisTemplate = config.getRedisTemplate(factory);
HashOperations<Object, Object, Object> ops = redisTemplate.opsForHash();
ops.put("it:group:1","name","Amy");
System.out.println("name="+ops.get("it:group:1","name"));
}
在可视化工具中,也能看到正常数值
注:感谢以上博主和黑马程序员的文章或图片
更多推荐
已为社区贡献1条内容
所有评论(0)