CreateCostElement:
* fix M_Cost creation * improved performances
This commit is contained in:
parent
ec95527738
commit
8937778bab
|
@ -12,17 +12,19 @@
|
||||||
* For the text or an alternative of this public license, you may reach us *
|
* For the text or an alternative of this public license, you may reach us *
|
||||||
* Copyright (C) 2003-2007 e-Evolution,SC. All Rights Reserved. *
|
* Copyright (C) 2003-2007 e-Evolution,SC. All Rights Reserved. *
|
||||||
* Contributor(s): Victor Perez www.e-evolution.com *
|
* Contributor(s): Victor Perez www.e-evolution.com *
|
||||||
|
* Teo Sarca, www.arhipac.ro *
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
package org.eevolution.process;
|
package org.eevolution.process;
|
||||||
|
|
||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
import java.sql.ResultSet;
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.SQLException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
|
|
||||||
import org.adempiere.exceptions.AdempiereException;
|
|
||||||
import org.adempiere.exceptions.DBException;
|
import org.adempiere.exceptions.DBException;
|
||||||
|
import org.compiere.model.MAcctSchema;
|
||||||
import org.compiere.model.MCost;
|
import org.compiere.model.MCost;
|
||||||
import org.compiere.model.MCostElement;
|
import org.compiere.model.MCostElement;
|
||||||
import org.compiere.model.MProduct;
|
import org.compiere.model.MProduct;
|
||||||
|
@ -33,10 +35,12 @@ import org.compiere.util.DB;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create Cost Element
|
* Create Cost Element
|
||||||
*
|
*
|
||||||
* @author victor.perez@e-evolution.com, e-Evolution, S.C.
|
* @author victor.perez@e-evolution.com, e-Evolution, S.C.
|
||||||
* @version $Id: CreateCostElement.java,v 1.1 2004/06/22 05:24:03 vpj-cd Exp $
|
* @version $Id: CreateCostElement.java,v 1.1 2004/06/22 05:24:03 vpj-cd Exp $
|
||||||
|
*
|
||||||
|
* @author Teo Sarca, www.arhipac.ro
|
||||||
*/
|
*/
|
||||||
public class CreateCostElement extends SvrProcess
|
public class CreateCostElement extends SvrProcess
|
||||||
{
|
{
|
||||||
|
@ -91,30 +95,54 @@ public class CreateCostElement extends SvrProcess
|
||||||
|
|
||||||
protected String doIt() throws Exception
|
protected String doIt() throws Exception
|
||||||
{
|
{
|
||||||
|
MAcctSchema as = MAcctSchema.get(getCtx(), p_C_AcctSchema_ID);
|
||||||
int count_costs = 0;
|
int count_costs = 0;
|
||||||
|
|
||||||
ArrayList<Object> params = new ArrayList<Object>();
|
ArrayList<Object> params = new ArrayList<Object>();
|
||||||
String sql = "SELECT M_Product_ID FROM M_Product WHERE AD_Client_ID=?";
|
String sql = "SELECT org.AD_Org_ID, p.M_Product_ID, ce.M_CostElement_ID"
|
||||||
|
+" FROM AD_Org org, M_Product p, M_CostElement ce"
|
||||||
|
+" WHERE ";
|
||||||
|
|
||||||
|
sql += "org.AD_Client_ID=? AND p.AD_Client_ID=org.AD_Client_ID AND ce.AD_Client_ID=p.AD_Client_ID";
|
||||||
params.add(getAD_Client_ID());
|
params.add(getAD_Client_ID());
|
||||||
if (p_M_Product_Category_ID != 0)
|
|
||||||
|
if (p_AD_Org_ID > 0)
|
||||||
{
|
{
|
||||||
sql = sql + " AND M_Product_Category_ID=?";
|
sql += " AND org.AD_Org_ID=?";
|
||||||
|
params.add(p_AD_Org_ID);
|
||||||
|
}
|
||||||
|
if (p_M_Product_Category_ID > 0)
|
||||||
|
{
|
||||||
|
sql += " AND p."+MProduct.COLUMNNAME_M_Product_Category_ID+"=?";
|
||||||
params.add(p_M_Product_Category_ID);
|
params.add(p_M_Product_Category_ID);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (p_M_Product_ID != 0)
|
if (p_M_Product_ID > 0)
|
||||||
{
|
{
|
||||||
sql = sql + " AND M_Product_ID=?";
|
sql += " AND p."+MProduct.COLUMNNAME_M_Product_ID+"=?";
|
||||||
params.add(p_M_Product_ID);
|
params.add(p_M_Product_ID);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (p_M_CostElement_ID > 0)
|
||||||
MCostElement[] elements = MCostElement.getElements(getCtx(), get_TrxName());
|
|
||||||
if (elements.length == 0)
|
|
||||||
{
|
{
|
||||||
throw new AdempiereException("@NotFound@ @M_CostElement_ID@");
|
sql += " AND ce."+MCostElement.COLUMNNAME_M_CostElement_ID+"=?";
|
||||||
|
params.add(p_M_CostElement_ID);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// M_Cost not already created:
|
||||||
|
sql += " AND NOT EXISTS (SELECT 1 FROM M_Cost c WHERE"
|
||||||
|
+" c.AD_Client_ID=ce.AD_Client_ID"
|
||||||
|
+" AND c.AD_Org_ID=org.AD_Org_ID"
|
||||||
|
+" AND c.M_Product_ID=p.M_Product_ID"
|
||||||
|
+" AND c.C_AcctSchema_ID=?"
|
||||||
|
+" AND c.M_CostType_ID=?"
|
||||||
|
+" AND c.M_CostElement_ID=ce.M_CostElement_ID)";
|
||||||
|
params.add(p_C_AcctSchema_ID);
|
||||||
|
params.add(p_M_CostType_ID);
|
||||||
|
|
||||||
|
// ORDER BY
|
||||||
|
sql += " ORDER BY p."+MProduct.COLUMNNAME_M_Product_ID;
|
||||||
|
|
||||||
PreparedStatement pstmt = null;
|
PreparedStatement pstmt = null;
|
||||||
ResultSet rs = null;
|
ResultSet rs = null;
|
||||||
try
|
try
|
||||||
|
@ -124,32 +152,21 @@ public class CreateCostElement extends SvrProcess
|
||||||
rs = pstmt.executeQuery ();
|
rs = pstmt.executeQuery ();
|
||||||
while (rs.next())
|
while (rs.next())
|
||||||
{
|
{
|
||||||
int m_M_Product_ID = rs.getInt(MProduct.COLUMNNAME_M_Product_ID);
|
int AD_Org_ID = rs.getInt("AD_Org_ID");
|
||||||
MCost[] costs = MCost.getCosts(getCtx(), getAD_Client_ID(), p_AD_Org_ID,
|
int M_Product_ID = rs.getInt(MProduct.COLUMNNAME_M_Product_ID);
|
||||||
m_M_Product_ID, p_M_CostType_ID, p_C_AcctSchema_ID,
|
int M_CostElement_ID = rs.getInt(MCostElement.COLUMNNAME_M_CostElement_ID);
|
||||||
get_TrxName());
|
int M_ASI_ID = 0;
|
||||||
if (costs.length == 0)
|
MProduct product = MProduct.get(getCtx(), M_Product_ID);
|
||||||
{
|
//
|
||||||
for(MCostElement element : elements)
|
MCost cost = new MCost(product, M_ASI_ID, as, AD_Org_ID, M_CostElement_ID);
|
||||||
{
|
cost.setM_CostType_ID(p_M_CostType_ID);
|
||||||
if(p_M_CostElement_ID > 0 && element.get_ID() != p_M_CostElement_ID)
|
cost.saveEx(get_TrxName());
|
||||||
continue;
|
count_costs++;
|
||||||
|
|
||||||
MCost cost = new MCost(getCtx(), 0, get_TrxName());
|
|
||||||
cost.setM_Product_ID(m_M_Product_ID);
|
|
||||||
cost.setAD_Org_ID(p_AD_Org_ID);
|
|
||||||
cost.setC_AcctSchema_ID(p_C_AcctSchema_ID);
|
|
||||||
cost.setM_CostType_ID(p_M_CostType_ID);
|
|
||||||
cost.setM_CostElement_ID(element.get_ID());
|
|
||||||
cost.saveEx();
|
|
||||||
count_costs++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (SQLException e)
|
||||||
{
|
{
|
||||||
throw new DBException(e);
|
throw new DBException(e, sql);
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
|
@ -159,5 +176,4 @@ public class CreateCostElement extends SvrProcess
|
||||||
|
|
||||||
return "@Created@ #"+count_costs;
|
return "@Created@ #"+count_costs;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // Create Cost Element
|
} // Create Cost Element
|
||||||
|
|
Loading…
Reference in New Issue