redishash只能存储string类型?解决:redisTemplate存储序列化对象
上⼀篇博⽂中
讲了redisTemplate的hash数据类型存储{key(String)->value(string)}的⽅法;
但是实际清楚我们存储对象应该是{key(string)->value(object)}类型的。
开始测试的时候,报错为 object can not cast to object,发现redis的hash类型只能存储string类型的数据。后经翻阅资料,到存储序列化对象的⽅法解决。
实现serializable接⼝的作⽤就是可以把对象转化为字节流,并且可以反序列化恢复,对象实现序列化可以进⾏⽹络传输,在分布式应⽤中,就需要进⾏序列化对象的操作。
1. implements Serializable实现对象可序列化:
pojo实现serializable接⼝,使其能够被序列化
import java.io.Serializable;
import batisplus.annotation.IdType;
import batisplus.annotation.TableId;
public class Student implements Serializable {
@TableId(type=IdType.AUTO)//标志主键为⾃增
private int stuid;
private String stuname;
private int status;
2. 序列化对象并存储
public void setmap() throws FileNotFoundException, IOException, ClassNotFoundException{
//这⾥使⽤序列化器Jackson2JsonRedisSerializer让redisTemplate⽀持序列化
redisTemplate.setHashValueSerializer(new Jackson2JsonRedisSerializer<>(Student.class));
//更新redisTemplate
redis支持的五种数据类型//为hash设置存储类型(map标志键名,散列key,散列value)
HashOperations<String, String, Object> miaoshamap=redisTemplate.opsForHash();
//从数据库获取student列表
List<Student> stulist=findall();
for (Student student : stulist) {
//序列化对象操作
ObjectOutputStream obi=null;
ByteArrayOutputStream bai=null;
bai=new ByteArrayOutputStream();
obi=new ObjectOutputStream(bai);
obi.writeObject(student);
byte[] ByteArray();
//保存序列化后的对象到redis缓存中
redisTemplate.boundHashOps("test").Stuid()),student);
}
//设置过期时间2000秒
}
得到保存结果如下
3. 取出map值并反序列化
public List getmap(){
//这⾥使⽤序列化器Jackson2JsonRedisSerializer让redisTemplate⽀持序列化
redisTemplate.setHashValueSerializer(new Jackson2JsonRedisSerializer<>(Student.class)); disTemplate=redisTemplate;
//根据刚才保存的map键名为test,得到其保存的值
List<Student> list=redisTemplate.boundHashOps("test").values();
for (Student student : list) {
System.out.Stuname());
}
return list;
}
运⾏结果
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论