IDEMPIERE-2698 Performance: Report checking for zoom condition on database - must be cached

This commit is contained in:
Carlos Ruiz 2015-06-25 14:50:22 -05:00
parent c2c9e369b5
commit 2998c976ac
1 changed files with 16 additions and 7 deletions

View File

@ -19,6 +19,7 @@ import java.sql.ResultSet;
import java.util.List; import java.util.List;
import java.util.Properties; import java.util.Properties;
import org.compiere.util.CCache;
import org.compiere.util.DB; import org.compiere.util.DB;
import org.compiere.util.Env; import org.compiere.util.Env;
import org.compiere.util.Evaluatee; import org.compiere.util.Evaluatee;
@ -60,6 +61,9 @@ public class MZoomCondition extends X_AD_ZoomCondition
super (ctx, rs, trxName); super (ctx, rs, trxName);
} // MZoomCondition } // MZoomCondition
/** Cache of Table Conditions Array **/
private static CCache<Integer,MZoomCondition[]> s_conditions = new CCache<Integer,MZoomCondition[]>(Table_Name, 0);
/** /**
* Retrieve zoom condition record by AD_Table_ID * Retrieve zoom condition record by AD_Table_ID
* @param AD_Table_ID * @param AD_Table_ID
@ -67,13 +71,18 @@ public class MZoomCondition extends X_AD_ZoomCondition
*/ */
public static MZoomCondition[] getConditions(int AD_Table_ID) public static MZoomCondition[] getConditions(int AD_Table_ID)
{ {
final String whereClauseFinal = "AD_Table_ID=?"; MZoomCondition[] conditions = s_conditions.get(AD_Table_ID);
List<MZoomCondition> list = new Query(Env.getCtx(), MZoomCondition.Table_Name, whereClauseFinal, null) if (conditions == null) {
.setParameters(AD_Table_ID) final String whereClauseFinal = "AD_Table_ID=?";
.setOnlyActiveRecords(true) List<MZoomCondition> list = new Query(Env.getCtx(), MZoomCondition.Table_Name, whereClauseFinal, null)
.setOrderBy(MZoomCondition.COLUMNNAME_SeqNo) .setParameters(AD_Table_ID)
.list(); .setOnlyActiveRecords(true)
return list.toArray(new MZoomCondition[list.size()]); .setOrderBy(MZoomCondition.COLUMNNAME_SeqNo)
.list();
conditions = list.toArray(new MZoomCondition[list.size()]);
s_conditions.put(AD_Table_ID, conditions);
}
return conditions;
} // getConditions } // getConditions
private static int findZoomWindowByTableId(int AD_Table_ID, MQuery query) private static int findZoomWindowByTableId(int AD_Table_ID, MQuery query)