优点:虽然需要序列化和反序列化,但是可以直接操作对象的方法,方便快捷
缺点:需要序列化和反序列化,并且修改单个字段,需要获取整个json,修改后,序列化保存,浪费空间,浪费时间,效率低
1.2 采用redis hash key field value 存储key代表主键,比如用户id,或者openId,value是一个map,对应各个字段的属性和值
存放单个字段
存放整个:
优点:存储方方便,节省内存空间,并且可以直接对单个字段修改,而不用获取整个对象,效率高
缺点:获取value后,是个map,不能方便的直接调用(set get)处理,需要手动map.get(filed)或者map.put(field,value)
1.3 如何解决redis hash存储对象的操作方便性问题其实关于map和pojo的转换问题,网上给出了利用反射做的转换方法,但是加上了转换和反转,这和序列化和反序列化的问题一样了,效率问题,也不敢指直接用,纠结,思考再三,还是先维持代码不动了,以后考虑好了再说,或者广发网友有啥好解决方法,请多多指教哈!
Redis存储对象的三种方式 一、 将对象序列化后保存到Redis序列化工具类实现
获取jedis实例
redis操作类
User对象
测试
二、将对象用FastJSON转为JSON字符串后存储redis操作类
测试
三、将对象用Hash数据类型存储redis操作类
测试
以上为个人经验,希望能给大家一个参考,也希望大家多多支持七叶笔记。