上一篇博文中
讲了redisTemplate的hash数据类型存储{key(String)->value(string)}的方法;
但是实际清楚我们存储对象应该是{key(string)->value(object)}类型的。
开始测试的时候,报错为 object can not cast to object,发现redis的hash类型只能存储string类型的数据。后经翻阅资料,找到存储序列化对象的方法解决。
实现serializable接口的作用就是可以把对象转化为字节流,并且可以反序列化恢复,对象实现序列化可以进行网络传输,在分布式应用中,就需要进行序列化对象的操作。
- implements Serializable实现对象可序列化:
pojo实现serializable接口,使其能够被序列化
import java.io.Serializable;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
public class Student implements Serializable {
@TableId(type=IdType.AUTO)//标志主键为自增
private int stuid;
private String stuname;
private int status;
- 序列化对象并存储
public void setmap() throws FileNotFoundException, IOException, ClassNotFoundException{
//这里使用序列化器Jackson2JsonRedisSerializer让redisTemplate支持序列化
redisTemplate.setHashValueSerializer(new Jackson2JsonRedisSerializer<>(Student.class));
//更新redisTemplate
this.redisTemplate=redisTemplate;
//为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[] byt=bai.toByteArray();
//保存序列化后的对象到redis缓存中
redisTemplate.boundHashOps("test").put(Integer.toString(student.getStuid()),student);
}
//设置过期时间2000秒
redisTemplate.expire("test", 2000, TimeUnit.SECONDS);
}
得到保存结果如下
- 取出map值并反序列化
public List getmap(){
//这里使用序列化器Jackson2JsonRedisSerializer让redisTemplate支持序列化
redisTemplate.setHashValueSerializer(new Jackson2JsonRedisSerializer<>(Student.class));
this.redisTemplate=redisTemplate;
//根据刚才保存的map键名为test,得到其保存的值
List<Student> list=redisTemplate.boundHashOps("test").values();
for (Student student : list) {
System.out.println(student.getStuname());
}
return list;
}
运行结果