微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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中取出,是单独取该对象的单个属性

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐