代码很简单。从“供应商详细信息”表单中,如果您转到“功能”>“更新1099”,则用户希望在所有供应商上执行此操作,而不是手动执行此操作。我修改了基本的VendTax1099Update类来扩展RunBaseBatch,然后添加了一堆parm方法。我收到此错误,但任务存在?我做错了吗?
“无法创建依赖项,因为任务供应商更新的税1099信息不存在。”
我把它设为“addDependency”,因为当我试图将它打开时,有数据库锁。不确定是否有办法解决这些问题。
void run()
{
BatchHeader batchHeader;
VendTax1099Update vendTax1099Update;
VendTax1099Update vendTax1099UpdateOld;
VendTable vendTable;
boolean first = true;
;
/*
if (this.isInBatch())
{
*/
// Make sure there is a batch header
if (!batchHeader)
batchHeader = BatchHeader::construct(this.parmCurrentBatch().BatchJobId);
while select vendTable
where vendTable.Tax1099Reports == true &&
vendTable.Tax1099Box != ''
{
if (Tax1099Fields::exist(vendTable.Tax1099Box))
{
vendTax1099Update = new VendTax1099Update();
vendTax1099Update.parmFromDate(fromDate);
vendTax1099Update.parmToDate(toDate);
vendTax1099Update.parmRecalcAmounts(recalcAmounts);
vendTax1099Update.parmSetAll1099(setAll1099);
vendTax1099Update.parmBoxFor1099(vendTable.Tax1099Box);
vendTax1099Update.parmVendorNum(vendTable.AccountNum);
if (first)
{
batchHeader.addRuntimeTask(vendTax1099Update, this.parmCurrentBatch().RecId);
first = false;
}
else
{
if (vendTax1099UpdateOld)
batchHeader.addDependency(vendTax1099Update, vendTax1099UpdateOld, BatchDependencyStatus::FinishedOrError);
}
vendTax1099UpdateOld = vendTax1099Update;
}
else
error (strfmt("Unable to process %1 because %2 was not found in Tax1099Fields", vendTable.AccountNum, vendTable.Tax1099Box));
}
/*
}
*/
if (batchHeader)
batchHeader.save();
}
答案 0 :(得分:2)
我一直在绞尽脑汁工作几个小时,当然在发布后几分钟我意识到我可以进入batchHeader.addDependency()方法后解决问题。
原来你必须添加任务,然后设置依赖关系。我认为设置依赖性也是同样添加任务。纠正的代码位是:
vendTax1099Update.parmBoxFor1099(vendTable.Tax1099Box);
vendTax1099Update.parmVendorNum(vendTable.AccountNum);
batchHeader.addRuntimeTask(vendTax1099Update, this.parmCurrentBatch().RecId);
if (vendTax1099UpdateOld)
batchHeader.addDependency(vendTax1099Update, vendTax1099UpdateOld, BatchDependencyStatus::FinishedOrError);
vendTax1099UpdateOld = vendTax1099Update;
}
else