我有一个自定义实用程序,它使用AX 2012 AOT中的自定义表,我希望我的表有一个标识字段,有人告诉我我可以使用数字序列,并可以将数字序列映射到我的表所以它可以在行插入时获得一个新的唯一ID,当我尝试生成数字序列时,它会询问我AREA和模块信息,因为我想要这个用于我的自定义表和实用程序,它在动态轴外使用.net工作业务连接器,我无法弄清楚输入向导的内容。
答案 0 :(得分:4)
您可能已经看到了使用NumberSeqModule枚举并向其添加自定义模块枚举值的方法。然后,您通常会创建一个扩展NumberSeqApplicationModule类的类,然后使用数字序列引用加载链接到数据类型的数字序列。
虽然这是“最佳实践方式”,但对于您现在想要做的事情来说,这有点过分。所以你可以做到这一点:
您可以覆盖正在使用的表的插入方法。您可以在NumberSeq类上使用newGetNumFromCode构造函数。
public static NumberSeq newGetNumFromCode(
NumberSequenceCode _numberSequenceCode,
NumberSeqScope _scope = NumberSeqScopeFactory::createDefaultScope(),
boolean _makeDecisionLater = false,
boolean _dontThrowOnMissingRefSetUp = false,
SysLastValue _nextNumSeq = null,
boolean _fillNextNumSeq = false)
{
return NumberSeq::newGetNumFromId(
NumberSequenceTable::findByNaturalKey(_numberSequenceCode, _scope.getId()).RecId,
_makeDecisionLater,
_dontThrowOnMissingRefSetUp,
_nextNumSeq,
_fillNextNumSeq);
}
现在要使用它,您只需在Dynamics Ax(组织管理|数字序列|数字序列)中创建一个新的数字序列,并记住数字序列代码。
然后在表的insert方法中,您可以执行以下操作:(示例来自联系人表)
if (!this.ContactPersonId)
{
this.ContactPersonId = NumberSeq::newGetNum(CompanyInfo::numRefContactPersonId()).num();
}
这应确保在插入记录时,您还将填写ID。
答案 1 :(得分:1)
这是你用正常方式编号序列的方式
custTable.xyz = NumberSeq::newGetNum(CompanyInfo::numrefContactId()).num();