Redis的hash结构经典场景--存储对象

2021/9/16 2:08:59

本文主要是介绍Redis的hash结构经典场景--存储对象,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

redis中的hash结构数据结构,就是value类型为hash【和java中的hash结构一样】

Map<String,HashMap<String,String>> hash=newHashMap<String,HashMap<String,String>>();

每个hash【是value位置上的第二个hash】的存储大小:可以存储2的(32-1)方的键值对【40多亿】

Redis存储java对象:

redis 存储java对象一般是string 和 hash两种,但是两个使用的场景不同:

1.String的存储通常用在频繁读操作场景,它的存储格式是json,即将java对象转成json格式,然后存入redis。

2.hash的存储通常用在频繁写操作场景,即当对象的某个属性需要频繁修改时,就不适合使用String+Json 这种数据格式【不灵活,每次修改都需要将对象转成json】

如果采用hash,直接对某个属性直接修改,不用序列化去修改整个对象,例如:商品的库存,价格,评论数,关注度经常变换,就需要使用hash存储。

使用SpringBoot +Redis+Hash存储商品数据

注意:使用redis的hash仍然需要序列化,注意不要使用默认的序列化,要重写

redis的配置文件:

 

      将对象中的属性和值转成map对象 ,使用了反射原理

代码如下:

public static Map<String, Object> objectToMap(Object obj) {
		if (obj == null) {
			return null;
		}

		Map<String, Object> map = new HashMap<String, Object>();
		try {
			Field[] declaredFields = obj.getClass().getDeclaredFields();
			for (Field field : declaredFields) {
				field.setAccessible(true);
				map.put(field.getName(), field.get(obj));
			}
		} catch (Exception e) {
			
		}

		return map;
	}

redis代码:

 

 key应该是对象的唯一标识id,这里写死了, 从redis中取出,是单独取该对象的单个属性



这篇关于Redis的hash结构经典场景--存储对象的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程