axapta - 按语句 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!");
解决方案
您尝试的逻辑不会像书面那样工作,而且它真的没有意义。您可以尝试以下方法。这标识了实际项目。您的代码(如果有效)只是查看整个表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));
}
推荐阅读
- laravel - 资源控制器中的自定义路由
- c++ - 使用 std::sort 时如何理解这个结果?
- ios - 从联合身份凭证获取 AWS Cognito JWT 令牌
- html - 如何使用 ngModel 将动态数据与输入字段绑定
- python - 猴子补丁 created_by 和 modified_by django
- entity-framework-core - 实体框架,基于列值的多个一对多关系
- python - 在 pyspark 数据帧的单个“when”函数中对数组的每个元素使用 OR 运算符
- c# - C# - SerialDataReceivedEventHandler 在第二个事件上执行(第一个事件总是被跳过)
- sparql - 从 GraphDB 查询 Geonames 数据
- javascript - Animate(transformX):是否可以在到达父div的角落后消失div