这两天在做项目的时候,根据几个条件查询结果,查询条件一样,多次点击查询,在firebug里面看响应时间慢慢增加,最后居然要20多秒, 导致流产,后台报如题错误,内存溢出了。
这个情况也有些不稳定,有时候会出现这种问题
数据库的记录不多,95条记录,所以排除了结果数太多导致的内存溢出原因
主要关联到了3个表:LimsDeteContractSample a、LimsDeteSampleDictionary b、LimsDeteModelSpecification c
a<-->b 多对多关系
b<-->c一对多关系
hibernate在加载a的时候,同时会吧b、c都load出来,所以,我在找出95条a记录时,同时会去load b和c,这样导致返回list集合的响应时间比较长,但我觉得这个还不至于导致多次查询最终内存溢出。
我在代码里进行循环的时候还用的了HashMap,查看资料说内存溢出与HashMap中的对象没有被及时销毁有关系,后来尝试使用WeakHashMap替代了HashMap,也没有解决问题。
我也知道可以再Eclipse设置JVM的内存大小,但我不觉得是由于内存不够导致的内存溢出,应该是内存泄露吧。
但苦苦没有发现原因。
后查询台代码如下:
sqlBuf.append("select {ldcs.*} from lims_dete_contract_sample ldcs ");
sqlBuf.append(" join lims_dete_sample_dictionary dic on dic.class2 = ldcs.sample_id");
sqlBuf.append(" join lims_dete_model_specification model on model.model_id = ldcs.model_id");
sqlBuf.append(" join lims_dete_contract ldc on ldc.contract_id = ldcs.contract_id ");
sqlBuf.append(" join lims_customer entrust on entrust.customer_id = ldc.commissioned_customer_id");
sqlBuf.append(" join lims_customer product on product.customer_id = ldc.production_customer_id");
//后面会插入简单where语句
//下面把查询出来的list遍历,把满足条件的放入HashMap里面,最后遍历map返回结果就ok了
List<LimsDeteContractSample> csList = hibernateTemplateDAO.createSQLQuery(sqlBuf.toString()).addEntity("ldcs",LimsDeteContractSample.class).list();
//List<LimsDeteContractSample> csList = hibernateTemplateDAO.find("from LimsDeteContractSample");
Map<LimsDeteContractSample,Integer> ldcsMap = new HashMap<LimsDeteContractSample,Integer>();
Set<LimsDeteContractSampleReceive> recSet = null;
int recNum = 0;
if(csList != null && csList.size() > 0){
for(LimsDeteContractSample cs : csList){
recSet = cs.getLimsDeteContractSampleReceives();
recNum = 0;
for(LimsDeteContractSampleReceive rec : recSet){
recNum += rec.getReceiveNumber();
}
if(cs.getContractAmount() > recNum)
ldcsMap.put(cs, recNum);
}
}
请大家帮忙查找原因,谢谢
刚刚出现了这个问题,如下图