分组计数 AX2012 R3
Count of group by statement AX2012 R3
我想按语句值分组并写控件。
有一个 table 有 3 个字段; ItemId、TaxGroup 和 TaxItemGroup。相同的 itemId 必须具有相同的 taxgroup 和 taxItemGroup 值。如果具有相同 ItemId 的行具有不同的税值,我应该抛出异常。
我写了这个代码但是这个 return 所有记录的数量。这个控件怎么写?
while select count(RecId) from ActivityLineExtraLcl
group by Itemid, TaxGroup, TaxItemGroup
where ActivityLineExtraLcl.Amount != 0
if(ActivityLineExtraLcl.RecId > 1 )
throw error("Same ItemIds can't have different values!");
您尝试的逻辑不会像写的那样工作,而且没有任何意义。您可以尝试以下操作。这标识了实际项目。您的代码(如果有效)只是查看整个 table ActivityLineExtraLcl
是否有任何问题。
ActivityLineExtraLcl ActivityLineExtraLcl;
ActivityLineExtraLcl ActivityLineExtraLclExists;
while select ItemId from ActivityLineExtraLcl
group by ItemId
where ActivityLineExtraLcl.Amount != 0
exists join ActivityLineExtraLclExists
where ActivityLineExtraLclExists.ItemId == ActivityLineExtraLcl.ItemId &&
ActivityLineExtraLclExists.Amount != 0 &&
(ActivityLineExtraLclExists.TaxGroup != ActivityLineExtraLcl.TaxGroup ||
ActivityLineExtraLclExists.TaxItemGroup != ActivityLineExtraLcl.TaxItemGroup)
{
error(strFmt("Item '%1' has different tax values", ActivityLineExtraLcl.ItemId));
}
我想按语句值分组并写控件。
有一个 table 有 3 个字段; ItemId、TaxGroup 和 TaxItemGroup。相同的 itemId 必须具有相同的 taxgroup 和 taxItemGroup 值。如果具有相同 ItemId 的行具有不同的税值,我应该抛出异常。
我写了这个代码但是这个 return 所有记录的数量。这个控件怎么写?
while select count(RecId) from ActivityLineExtraLcl
group by Itemid, TaxGroup, TaxItemGroup
where ActivityLineExtraLcl.Amount != 0
if(ActivityLineExtraLcl.RecId > 1 )
throw error("Same ItemIds can't have different values!");
您尝试的逻辑不会像写的那样工作,而且没有任何意义。您可以尝试以下操作。这标识了实际项目。您的代码(如果有效)只是查看整个 table ActivityLineExtraLcl
是否有任何问题。
ActivityLineExtraLcl ActivityLineExtraLcl;
ActivityLineExtraLcl ActivityLineExtraLclExists;
while select ItemId from ActivityLineExtraLcl
group by ItemId
where ActivityLineExtraLcl.Amount != 0
exists join ActivityLineExtraLclExists
where ActivityLineExtraLclExists.ItemId == ActivityLineExtraLcl.ItemId &&
ActivityLineExtraLclExists.Amount != 0 &&
(ActivityLineExtraLclExists.TaxGroup != ActivityLineExtraLcl.TaxGroup ||
ActivityLineExtraLclExists.TaxItemGroup != ActivityLineExtraLcl.TaxItemGroup)
{
error(strFmt("Item '%1' has different tax values", ActivityLineExtraLcl.ItemId));
}