IDEMPIERE-5407 Heavy query in MRole repeated too often (FHCA-3883) (#1465)

Removed the method MRole.loadTableInfo which loaded the arrays: m_tableAccessLevel, m_tableName, m_viewName, m_tableIdName
and replaced all usage with visits to cached information from tables or columns
This commit is contained in:
Carlos Ruiz 2022-09-06 09:01:06 +02:00 committed by GitHub
parent 537cb8b9b8
commit 0e71fa9884
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 25 additions and 80 deletions

View File

@ -33,7 +33,6 @@ import java.util.Iterator;
import java.util.List; import java.util.List;
import java.util.Map.Entry; import java.util.Map.Entry;
import java.util.Properties; import java.util.Properties;
import java.util.Set;
import java.util.logging.Level; import java.util.logging.Level;
import org.adempiere.exceptions.AdempiereException; import org.adempiere.exceptions.AdempiereException;
@ -68,7 +67,8 @@ public final class MRole extends X_AD_Role implements ImmutablePOSupport
/** /**
* *
*/ */
private static final long serialVersionUID = 7597852750014990009L; private static final long serialVersionUID = -8937680640915708588L;
/** /**
* Get Default (Client) Role * Get Default (Client) Role
@ -336,10 +336,6 @@ public final class MRole extends X_AD_Role implements ImmutablePOSupport
this.m_columnAccess = copy.m_columnAccess != null ? Arrays.copyOf(copy.m_columnAccess, copy.m_columnAccess.length) : null; this.m_columnAccess = copy.m_columnAccess != null ? Arrays.copyOf(copy.m_columnAccess, copy.m_columnAccess.length) : null;
this.m_recordAccess = copy.m_recordAccess != null ? Arrays.copyOf(copy.m_recordAccess, copy.m_recordAccess.length) : null; this.m_recordAccess = copy.m_recordAccess != null ? Arrays.copyOf(copy.m_recordAccess, copy.m_recordAccess.length) : null;
this.m_recordDependentAccess = copy.m_recordDependentAccess != null ? Arrays.copyOf(copy.m_recordDependentAccess, copy.m_recordDependentAccess.length) : null; this.m_recordDependentAccess = copy.m_recordDependentAccess != null ? Arrays.copyOf(copy.m_recordDependentAccess, copy.m_recordDependentAccess.length) : null;
this.m_tableAccessLevel = copy.m_tableAccessLevel != null ? new HashMap<Integer, String>(copy.m_tableAccessLevel) : null;
this.m_tableName = copy.m_tableName != null ? new HashMap<String, Integer>(copy.m_tableName) : null;
this.m_viewName = copy.m_viewName != null ? new HashSet<String>(copy.m_viewName) : null;
this.m_tableIdName = copy.m_tableIdName != null ? new HashMap<String, String>(copy.m_tableIdName) : null;
this.m_windowAccess = copy.m_windowAccess != null ? new HashMap<Integer, Boolean>(copy.m_windowAccess) : null; this.m_windowAccess = copy.m_windowAccess != null ? new HashMap<Integer, Boolean>(copy.m_windowAccess) : null;
this.m_processAccess = copy.m_processAccess != null ? new HashMap<Integer, Boolean>(copy.m_processAccess) : null; this.m_processAccess = copy.m_processAccess != null ? new HashMap<Integer, Boolean>(copy.m_processAccess) : null;
this.m_taskAccess = copy.m_taskAccess != null ? new HashMap<Integer, Boolean>(copy.m_taskAccess) : null; this.m_taskAccess = copy.m_taskAccess != null ? new HashMap<Integer, Boolean>(copy.m_taskAccess) : null;
@ -708,16 +704,7 @@ public final class MRole extends X_AD_Role implements ImmutablePOSupport
private MRecordAccess[] m_recordAccess = null; private MRecordAccess[] m_recordAccess = null;
/** List of Dependent Record Access */ /** List of Dependent Record Access */
private MRecordAccess[] m_recordDependentAccess = null; private MRecordAccess[] m_recordDependentAccess = null;
/** Table Data Access Level */
private HashMap<Integer,String> m_tableAccessLevel = null;
/** Table Name */
private HashMap<String,Integer> m_tableName = null;
/** View Name */
private Set<String> m_viewName = null;
/** ID Column Name **/
private HashMap<String,String> m_tableIdName = null;
/** Window Access */ /** Window Access */
private HashMap<Integer,Boolean> m_windowAccess = null; private HashMap<Integer,Boolean> m_windowAccess = null;
/** Process Access */ /** Process Access */
@ -758,7 +745,6 @@ public final class MRole extends X_AD_Role implements ImmutablePOSupport
{ {
loadOrgAccess(reload); loadOrgAccess(reload);
loadTableAccess(reload); loadTableAccess(reload);
loadTableInfo(reload);
loadColumnAccess(reload); loadColumnAccess(reload);
loadRecordAccess(reload); loadRecordAccess(reload);
if (reload) if (reload)
@ -955,56 +941,6 @@ public final class MRole extends X_AD_Role implements ImmutablePOSupport
if (log.isLoggable(Level.FINE)) log.fine("#" + m_tableAccess.length); if (log.isLoggable(Level.FINE)) log.fine("#" + m_tableAccess.length);
} // loadTableAccess } // loadTableAccess
/**
* Load Table Access and Name
* @param reload reload
*/
private void loadTableInfo (boolean reload)
{
if (m_tableAccessLevel != null && m_tableName != null && !reload)
return;
m_tableAccessLevel = new HashMap<Integer,String>(300);
m_tableName = new HashMap<String,Integer>(300);
m_viewName = new HashSet<String>(300);
m_tableIdName = new HashMap<String,String>(300);
PreparedStatement pstmt = null;
ResultSet rs = null;
String sql = "SELECT AD_Table_ID, AccessLevel, TableName, IsView, "
+ "(SELECT ColumnName FROM AD_COLUMN WHERE AD_COLUMN.AD_TABLE_ID = AD_TABLE.AD_TABLE_ID AND UPPER(AD_COLUMN.COLUMNNAME) = UPPER(AD_TABLE.TABLENAME) || '_ID') "
+ "FROM AD_Table WHERE IsActive='Y'";
try
{
pstmt = DB.prepareStatement(sql, get_TrxName());
rs = pstmt.executeQuery();
while (rs.next())
{
Integer ii = Integer.valueOf(rs.getInt(1));
m_tableAccessLevel.put(ii, rs.getString(2));
String tableName = rs.getString(3);
m_tableName.put(tableName, ii);
String isView = rs.getString(4);
if ("Y".equals(isView))
{
m_viewName.add(tableName.toUpperCase());
}
String idColumn = rs.getString(5);
if (idColumn != null && idColumn.trim().length() > 0)
{
m_tableIdName.put(tableName.toUpperCase(), idColumn);
}
}
}
catch (Exception e)
{
log.log(Level.SEVERE, sql, e);
}
finally
{
DB.close(rs, pstmt);
}
if (log.isLoggable(Level.FINE)) log.fine("#" + m_tableAccessLevel.size());
} // loadTableAccessLevel
/** /**
* Check if tableName is a view * Check if tableName is a view
* @param tableName * @param tableName
@ -1012,14 +948,21 @@ public final class MRole extends X_AD_Role implements ImmutablePOSupport
*/ */
private boolean isView(String tableName) private boolean isView(String tableName)
{ {
if (m_viewName == null) MTable table = MTable.get(getCtx(), tableName);
loadAccess(true); if (table == null)
return m_viewName.contains(tableName.toUpperCase()); return false;
return MTable.get(getCtx(), tableName).isView();
} }
private String getIdColumnName(String tableName) private String getIdColumnName(String tableName)
{ {
return m_tableIdName.get(tableName.toUpperCase()); StringBuilder colkey = new StringBuilder(tableName).append("_ID");
MTable table = MTable.get(getCtx(), tableName);
if (table == null)
return null;
if (MTable.get(getCtx(), tableName).columnExists(colkey.toString()))
return colkey.toString();
return null;
} }
/** /**
@ -1421,12 +1364,15 @@ public final class MRole extends X_AD_Role implements ImmutablePOSupport
{ {
if (ro) // role can always read if (ro) // role can always read
return true; return true;
//
loadTableInfo(false);
// AccessLevel // AccessLevel
// 1 = Org - 2 = Client - 4 = System // 1 = Org - 2 = Client - 4 = System
// 3 = Org+Client - 6 = Client+System - 7 = All // 3 = Org+Client - 6 = Client+System - 7 = All
String roleAccessLevel = (String)m_tableAccessLevel.get(Integer.valueOf(AD_Table_ID)); MTable table = MTable.get(AD_Table_ID);
if (table == null) {
log.warning("No Table Found with AD_Table_ID=" + AD_Table_ID);
return false;
}
String roleAccessLevel = table.getAccessLevel();
if (roleAccessLevel == null) if (roleAccessLevel == null)
{ {
if (log.isLoggable(Level.FINE)) log.fine("NO - No AccessLevel - AD_Table_ID=" + AD_Table_ID); if (log.isLoggable(Level.FINE)) log.fine("NO - No AccessLevel - AD_Table_ID=" + AD_Table_ID);
@ -2463,11 +2409,10 @@ public final class MRole extends X_AD_Role implements ImmutablePOSupport
*/ */
private int getAD_Table_ID (String tableName) private int getAD_Table_ID (String tableName)
{ {
loadTableInfo(false); MTable table = MTable.get(getCtx(), tableName);
Integer ii = (Integer)m_tableName.get(tableName); if (table == null)
if (ii != null) return 0;
return ii.intValue(); return table.getAD_Table_ID();
return 0;
} // getAD_Table_ID } // getAD_Table_ID
/** /**