上一篇博文中
讲了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 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;
  1. 序列化对象并存储
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);
	}

得到保存结果如下

RedissonClient中的bucket redistbutable_hash

  1. 取出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;
	}

运行结果

RedissonClient中的bucket redistbutable_redis_02