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