前提提要:这个是个人小白总结,写完博客后开始厌蠢。
redisTemplate 有两种插入hash的方式
redisTemplate.opsForHash().putAll(key, map);
redisTemplate.opsForHash().put(key, field, value);
在使用的过程中,难免会疑问为什么 key field value 序列化的方式,尤其是fields 的序列化方式。
因为在配置序列化方式的时候
只配置了如下:
redisTemplate.setHashKeySerializer(new StringRedisSerializer()); redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);
@Bean
public RedisTemplate<String, Object> jsonRedisTemplate() {
RedisTemplate redisTemplate = new RedisTemplate<>();
redisTemplate.setConnectionFactory(lettuceConnectionFactory);
// 使用Jackson2JsonRedisSerializer 替换默认的JDKSerializationRedisSerializer 来序列化和反序列化redis 的value值
Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
redisTemplate.setValueSerializer(new StringRedisSerializer());
// hash的value序列化方式采用jackson
redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setHashKeySerializer(new StringRedisSerializer());
redisTemplate.afterPropertiesSet();
return redisTemplate;
}
ok,废话不多说,先说结果,后分析
疑问:hash如何序列化的,重点:fields 是如何序列化的?
结论:
key: KeySerializer
fields: HashKeySerializer
value: HashValueSerializer
分析:
从上面两个图可以看到key,fields,value 是不同方式的序列化方式