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仍然需要序列化,注意不要使用默认的序列化,要重写
将对象中的属性和值转成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;
}
key应该是对象的唯一标识id,这里写死了, 从redis中取出,是单独取该对象的单个属性
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。