FR [ 2079083 ] Add MFactAcct.deleteEx method

This commit is contained in:
teo_sarca 2008-08-27 20:54:17 +00:00
parent 7c98840275
commit c1e2d1cc4a
6 changed files with 56 additions and 35 deletions

View File

@ -307,8 +307,7 @@ public final class MAllocationHdr extends X_C_AllocationHdr implements DocAction
return false; return false;
} }
setPosted(false); setPosted(false);
if (MFactAcct.delete (Table_ID, get_ID(), trxName) < 0) MFactAcct.deleteEx (Table_ID, get_ID(), trxName);
return false;
} }
// Mark as Inactive // Mark as Inactive
setIsActive(false); // updated DB for line delete/process setIsActive(false); // updated DB for line delete/process
@ -721,8 +720,7 @@ public final class MAllocationHdr extends X_C_AllocationHdr implements DocAction
throw new IllegalStateException("Cannot de-activate allocation"); throw new IllegalStateException("Cannot de-activate allocation");
// Delete Posting // Delete Posting
int no = MFactAcct.delete(MAllocationHdr.Table_ID, getC_AllocationHdr_ID(), get_TrxName()); MFactAcct.deleteEx(MAllocationHdr.Table_ID, getC_AllocationHdr_ID(), get_TrxName());
log.fine("Fact_Acct deleted #" + no);
// Unlink Invoices // Unlink Invoices
getLines(true); getLines(true);

View File

@ -466,8 +466,7 @@ public class MBankStatement extends X_C_BankStatement implements DocAction
m_processMsg = "@PeriodClosed@"; m_processMsg = "@PeriodClosed@";
return false; return false;
} }
if (MFactAcct.delete(Table_ID, getC_BankStatement_ID(), get_TrxName()) < 0) MFactAcct.deleteEx(Table_ID, getC_BankStatement_ID(), get_TrxName());
return false; // could not delete
} }
//Added Lines by AZ Goodwill //Added Lines by AZ Goodwill

View File

@ -680,10 +680,8 @@ public class MCash extends X_C_Cash implements DocAction
throw new IllegalStateException("Cannot save journal cash"); throw new IllegalStateException("Cannot save journal cash");
// Delete Posting // Delete Posting
String sql = "DELETE FROM Fact_Acct WHERE AD_Table_ID=" + MCash.Table_ID MFactAcct.deleteEx(Table_ID, getC_Cash_ID(), get_TrxName());
+ " AND Record_ID=" + getC_Cash_ID();
int no = DB.executeUpdate(sql, get_TrxName());
log.fine("Fact_Acct deleted #" + no);
return true; return true;
} // reverse } // reverse

View File

@ -16,10 +16,13 @@
*****************************************************************************/ *****************************************************************************/
package org.compiere.model; package org.compiere.model;
import java.sql.*; import java.sql.ResultSet;
import java.util.*; import java.util.Properties;
import java.util.logging.*; import java.util.logging.Level;
import org.compiere.util.*;
import org.adempiere.exceptions.DBException;
import org.compiere.util.CLogger;
import org.compiere.util.DB;
/** /**
@ -27,30 +30,52 @@ import org.compiere.util.*;
* *
* @author Jorg Janke * @author Jorg Janke
* @version $Id: MFactAcct.java,v 1.3 2006/07/30 00:51:03 jjanke Exp $ * @version $Id: MFactAcct.java,v 1.3 2006/07/30 00:51:03 jjanke Exp $
*
* @author Teo Sarca, http://www.arhipac.ro
* <li>FR [ 2079083 ] Add MFactAcct.deleteEx method
*/ */
public class MFactAcct extends X_Fact_Acct public class MFactAcct extends X_Fact_Acct
{ {
private static final long serialVersionUID = 1L;
/** /**
* Delete Accounting * Delete Accounting
* @param AD_Table_ID table * @param AD_Table_ID table
* @param Record_ID record * @param Record_ID record
* @param trxName transaction * @param trxName transaction
* @return number of rows or -1 for error * @return number of rows or -1 for error
* @deprecated Since ADempiere 3.5.2a; please use {@link #deleteEx(int, int, String)} instead.
*/ */
public static int delete (int AD_Table_ID, int Record_ID, String trxName) public static int delete00 (int AD_Table_ID, int Record_ID, String trxName)
{ {
StringBuffer sb = new StringBuffer(); int no = -1;
sb.append("DELETE Fact_Acct WHERE AD_Table_ID=").append(AD_Table_ID) try {
.append(" AND Record_ID=").append(Record_ID); no = deleteEx(AD_Table_ID, Record_ID, trxName);
int no = DB.executeUpdate(sb.toString(), trxName); }
if (no == -1) catch (DBException e) {
s_log.log(Level.SEVERE, "failed: AD_Table_ID=" + AD_Table_ID + ", Record_ID" + Record_ID); s_log.log(Level.SEVERE, "failed: AD_Table_ID=" + AD_Table_ID + ", Record_ID" + Record_ID, e);
else no = -1;
s_log.fine("delete - AD_Table_ID=" + AD_Table_ID }
+ ", Record_ID=" + Record_ID + " - #" + no);
return no; return no;
} // delete } // delete
/**
* Delete Accounting
* @param AD_Table_ID table
* @param Record_ID record
* @param trxName transaction
* @return number of rows deleted
* @throws DBException on database exception
*/
public static int deleteEx(int AD_Table_ID, int Record_ID, String trxName)
throws DBException
{
final String sql = "DELETE Fact_Acct WHERE AD_Table_ID=? AND Record_ID=?";
int no = DB.executeUpdateEx(sql, new Object[]{AD_Table_ID, Record_ID}, trxName);
s_log.fine("delete - AD_Table_ID=" + AD_Table_ID + ", Record_ID=" + Record_ID + " - #" + no);
return no;
}
/** Static Logger */ /** Static Logger */
private static CLogger s_log = CLogger.getCLogger (MFactAcct.class); private static CLogger s_log = CLogger.getCLogger (MFactAcct.class);

View File

@ -39,6 +39,9 @@ import org.compiere.util.Env;
*/ */
public class MMatchInv extends X_M_MatchInv public class MMatchInv extends X_M_MatchInv
{ {
private static final long serialVersionUID = 1L;
/** /**
* Get InOut-Invoice Matches * Get InOut-Invoice Matches
* @param ctx context * @param ctx context
@ -356,10 +359,9 @@ public class MMatchInv extends X_M_MatchInv
{ {
if (isPosted()) if (isPosted())
{ {
if (!MPeriod.isOpen(getCtx(), getDateTrx(), MDocType.DOCBASETYPE_MatchInvoice)) MPeriod.testPeriodOpen(getCtx(), getDateTrx(), MDocType.DOCBASETYPE_MatchInvoice);
return false;
setPosted(false); setPosted(false);
return MFactAcct.delete (Table_ID, get_ID(), get_TrxName()) >= 0; MFactAcct.deleteEx (Table_ID, get_ID(), get_TrxName());
} }
return true; return true;
} // beforeDelete } // beforeDelete

View File

@ -658,10 +658,9 @@ public class MMatchPO extends X_M_MatchPO
{ {
if (isPosted()) if (isPosted())
{ {
if (!MPeriod.isOpen(getCtx(), getDateTrx(), MDocType.DOCBASETYPE_MatchPO)) MPeriod.testPeriodOpen(getCtx(), getDateTrx(), MDocType.DOCBASETYPE_MatchPO);
return false;
setPosted(false); setPosted(false);
return MFactAcct.delete (Table_ID, get_ID(), get_TrxName()) >= 0; MFactAcct.deleteEx (Table_ID, get_ID(), get_TrxName());
} }
return true; return true;
} // beforeDelete } // beforeDelete