由于这几张表读取的非常频繁。于是便相对第一次查询的结果进行缓存。如果缓存中没有相应的数据再从数据库中读取。
现的问题,这个方法上要不要考滤同步的问题。
我是这样想的。当同一时刻有多个用户同时查询相同的数据时。此时要查询的数据刚好在缓存中没有。那么这时要从数据库中读取。
假设A查询时执行的到的代码为:List conInfoList = new ArrayList();
而B查询执行到代码为:if(pageConInfoMap.get(riskCode + comCode) != null)
那么现在的问题是A将结果查询出放入缓存。而B又一次将结果查询出放入缓存中。缓存用的是map不会产生重复记录的情况。
但是本来要查询一次数据库,其它的都要从缓存中读取。可是假设的情况却读了两次,在实际运行中,有可不只是两次。所以说我是否应当要取读数据进行缓存的方法设为同步呢。
代码如下:
已经将其设为同步的
public class PageAutoConfigServer {
private static final Map pageConInfoMap = new HashMap();
public synchronized List getPageConfigInfo(String riskCode, String comCode)
throws Exception {
if(pageConInfoMap.get(riskCode + comCode) != null){
return (List)pageConInfoMap.get(riskCode + comCode);
}
DbPool dbPool = new DbPool();
List conInfoList = new ArrayList();
try {
dbPool.open(SysConst.getProperty("DDCCDATASOURCE"));
conInfoList = new DBPageFiledAutoConfig().getPageElementsConfigInfo(riskCode, comCode, dbPool);
pageConInfoMap.put(riskCode + comCode, conInfoList);
} catch (Exception e) {
throw e;
} finally{
dbPool.close();
}
return conInfoList;
}
}
说明此方法是在jsp页面中直接调用的