本文整理汇总了C#中GLBatchTDS.Copy方法的典型用法代码示例。如果您正苦于以下问题:C# GLBatchTDS.Copy方法的具体用法?C# GLBatchTDS.Copy怎么用?C# GLBatchTDS.Copy使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类GLBatchTDS
的用法示例。
在下文中一共展示了GLBatchTDS.Copy方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: ProcessRecurringTransAndAttributesForDeletion
public static GLBatchTDS ProcessRecurringTransAndAttributesForDeletion(GLBatchTDS AMainDS,
Int32 ALedgerNumber,
Int32 ABatchNumber,
Int32 AJournalNumber,
Int32 AHighestTransactionNumber,
Int32 ATransactionToDelete)
{
#region Validate Arguments
if (AMainDS == null)
{
throw new EFinanceSystemDataObjectNullOrEmptyException(String.Format(Catalog.GetString(
"Function:{0} - The Recurring GL Batch dataset is null!"),
Utilities.GetMethodName(true)));
}
if (ALedgerNumber <= 0)
{
throw new EFinanceSystemInvalidLedgerNumberException(String.Format(Catalog.GetString(
"Function:{0} - The Ledger number must be greater than 0!"),
Utilities.GetMethodName(true)), ALedgerNumber);
}
else if (ABatchNumber <= 0)
{
throw new EFinanceSystemInvalidBatchNumberException(String.Format(Catalog.GetString(
"Function:{0} - The Recurring Batch number must be greater than 0!"),
Utilities.GetMethodName(true)), ALedgerNumber, ABatchNumber);
}
else if (AJournalNumber <= 0)
{
throw new ArgumentException(String.Format(Catalog.GetString("Function:{0} - The Recurring Journal number must be greater than 0!"),
Utilities.GetMethodName(true)));
}
else if (AHighestTransactionNumber <= 0)
{
throw new ArgumentException(String.Format(Catalog.GetString(
"Function:{0} - The highest Transaction number in the Recurring Journal must be greater than 0!"),
Utilities.GetMethodName(true)));
}
else if (ATransactionToDelete <= 0)
{
throw new ArgumentException(String.Format(Catalog.GetString(
"Function:{0} - The number of the Transaction to delete must be greater than 0!"),
Utilities.GetMethodName(true)));
}
#endregion Validate Arguments
GLBatchTDS MainDSCopy = (GLBatchTDS)AMainDS.Copy();
MainDSCopy.Merge(AMainDS);
MainDSCopy.AcceptChanges();
GLBatchTDS SubmitDS = (GLBatchTDS)AMainDS.Copy();
SubmitDS.Merge(AMainDS);
SubmitDS.AcceptChanges();
TDBTransaction Transaction = null;
bool SubmissionOK = false;
try
{
DBAccess.GDBAccessObj.BeginAutoTransaction(IsolationLevel.Serializable,
ref Transaction,
ref SubmissionOK,
delegate
{
//Delete current row+ (attributes first).
DataView attributesDV = new DataView(MainDSCopy.ARecurringTransAnalAttrib);
attributesDV.RowFilter = String.Format("{0}={1} AND {2}={3} AND {4}>={5}",
ARecurringTransAnalAttribTable.GetBatchNumberDBName(),
ABatchNumber,
ARecurringTransAnalAttribTable.GetJournalNumberDBName(),
AJournalNumber,
ARecurringTransAnalAttribTable.GetTransactionNumberDBName(),
ATransactionToDelete);
foreach (DataRowView attrDRV in attributesDV)
{
ARecurringTransAnalAttribRow attrRow = (ARecurringTransAnalAttribRow)attrDRV.Row;
attrRow.Delete();
}
DataView transactionsDV = new DataView(MainDSCopy.ARecurringTransaction);
transactionsDV.RowFilter = String.Format("{0}={1} AND {2}={3} AND {4}>={5}",
ARecurringTransactionTable.GetBatchNumberDBName(),
ABatchNumber,
ARecurringTransactionTable.GetJournalNumberDBName(),
AJournalNumber,
ARecurringTransactionTable.GetTransactionNumberDBName(),
ATransactionToDelete);
foreach (DataRowView transDRV in transactionsDV)
{
ARecurringTransactionRow tranRow = (ARecurringTransactionRow)transDRV.Row;
tranRow.Delete();
}
//Need to save changes before deleting any transactions
GLBatchTDSAccess.SubmitChanges(MainDSCopy);
//.........这里部分代码省略.........