首页 > 解决方案 > 按语句 AX2012 R3 分组计数

问题描述

我想按语句值计算分组并编写控制。

有一个有 3 个字段的表;ItemId、TaxGroup 和 TaxItemGroup。相同的 itemId 必须具有相同的 taxgroup 和 taxItemGroup 值。如果具有相同 ItemId 的行具有不同的税值,我应该抛出异常。

我写了这段代码,但是这个返回所有记录的数量。我该如何编写这个控件?

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!");

标签: axaptax++dynamics-ax-2012-r3

解决方案


您尝试的逻辑不会像书面那样工作,而且它真的没有意义。您可以尝试以下方法。这标识了实际项目。您的代码(如果有效)只是查看整个表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));
}

推荐阅读