下面的代码是数据层的,代码意思是,从缓存中获得用户的设置信息,如果没有就去数据库查询,并且放入缓存中。
public CoreMap queryOptions(String name, String userId) throws Exception {
CoreMap out = (CoreMap) CacheManager.get("SysOptions", "user_id_" + userId);//活动缓存
List<Object> list = new ArrayList<Object>();
if(out == null){
//.......
List<CoreMap> result = DBHepler.queryList(sql, params);
out = optionsListToMap(result);
CacheManager.set("SysOptions", "user_id_" + userId, (Serializable) out);//把out放入缓存
}
return out;
}
这里执行完之后,确实是把out变量的值放入了缓存。
但奇怪的地方是方法返回的时候,方法返回out,一层一层的返回到最初调用的地方。下次再取缓存值的时候就会出现多余的数据。。
貌似我也不好描述。。
简单点说,我缓存一个{name='', email='@gmail.com'}
,下次取出来就成了{name='', email='@gmail.com', url='http://sf.gg'}
,就是说会多出一些数据。
而这些多出的数据,是我最终要返回到页面上的数据。。
不知道这么说大家明白了没。。。
不知道是不是和值传递什么的相关,这个不太熟悉。
求解。。。
后续是不是给out的url变量赋值了?
评论里有点乱。整理下。
1.确保从DB中查询的出来的实例,不带有age,url属性;
2.实例放入缓存,手工从缓存中获取实例,看下情况;
3.如果上面正常。用上面的说的办法,看看能不能找到问题
这个可以debug跟踪下
1,确认下 第一次写入缓存的是否带url之类信息
2,如果1确认不带,那第二次读取的时候,是否是从缓存中读取的?