D365 FO财务维度

AX2012与之前AX版本最大的改变是财务维度,AX2012之前的版本,财务维度通过数组实现,默认只支持3个财务维度,可以花钱增加,但总数量受限且就一个主表维护,来源固定,很不灵活。
AX2012以后的财务维度不受限制,几乎所有的数据都可以拿来用做财务维度。
为了实现这个需求AX2012设计了复杂的表结构,对码农来说用AX2012之前直接读写表的方式来处理维度的相关逻辑,即便可能也是大费周章,还不见得能写对。
所以AX2012提供了很多辅助类来处理维度值,用的比较多的是AxdDimensionUtil,通过这个类的getLedgerAccountId方法可以得到LedgerDimension的值,通过getDimensionAttributeValueSetId方法可以得到DefualtDimension的值。
D365 FO代码里还能看到AxdDimensionUtil这个类,但是属性标记了是个废弃类。
[SysObsoleteAttribute('This class is no longer supported, use the DimensionResolver classes.', true)]
建议使用DimensionResolver去实现相应的功能,这个类本身是个抽象类,其子类如下图所示:

 我暂时只用了中间两个标记出来的类DimensionDynamicAccountResolver和DimensionDefaultResolver分别用来生成LedgerDimension和DefaultDimension,调用示例代码如下所示:

1 //Defalut Dimension
2         DimensionDefaultResolver        defaultResolver = DimensionDefaultResolver::newResolver("11-001-1010-080" + "-" +strReplace("CNMF-000001", "-", "\\-"));
3         RecId recId = defaultResolver.resolve();
4         info (int642Str(recId));
5 
6         //Ledger Dimension
7         DimensionDynamicAccountResolver  accountResolver = DimensionDynamicAccountResolver::newResolver("530198-11-001-1010-080");
8         recId = accountResolver.resolve();
9         info (int642Str(recId));

这个已经封装到没法再简洁了,只要一行代码就可以实现了,调用者唯一要做的就是按照 总账->会计科目表->维度->用于集成应用程序的财务维度配置 配置的结构,把字符串拼出来调用就可以了。
具体配置方法参见下文:
https://www.cnblogs.com/Farseer1215/p/12810071.html
当然D365 FO还提供了LedgerDimensionFacade和DimensionDefaultFacade封装了一些方法方便操作LedgerDimension和DefaultDimension,通过这些可以方便地获取需要的信息。

猜你喜欢

转载自www.cnblogs.com/Farseer1215/p/12818913.html
365
今日推荐