Ermitteln der reservierten Menge einer Auftragsposition für bestimmte Dimensionen
03.07.2014Microsoft Dynamics AX (Axapta)
|
Dieser Beitrag bezieht sich auf die Version:
Dynamics AX 2012
Dynamics AX 2012
|
|
|
|
|
|
Dieser Beitrag bezieht sich auf die Version:
Dynamics AX 2012
|
Mit Hilfe des folgenden Jobs kann man die reservierte Menge einer Auftragsposition ermitteln. Dabei kann man über einen InventDim-Datensatz jene Dimensionen angeben, für die man die Information benötigt.
{
InventTransIdSumSingleStatus inventTransIdSumSingleStatus;
SalesLine salesLine;
InventMovement inventMovement;
InventDim inventDim;
InventDimParm inventDimParmCriteria;
// Sales order line
salesLine = SalesLine::findInventTransId('012431');
inventMovement = InventTrans::findTransId(salesLine.InventTransId).inventMovement(true);
// Prepare inventDim-Record: Set Dimensions, which should be used
inventDim.clear();
inventDim.InventSiteId = "1";
inventDim.InventLocationId = "12";
inventDim.wmsLocationId = "12";
inventDim = InventDim::findOrCreate(inventDim);
inventDimParmCriteria.initFromInventDim(inventDim);
inventTransIdSumSingleStatus = InventTransIdSumSingleStatus::newTransOriginIdStatus(InventTransOriginSalesLine::findInventTransOriginId(salesLine.DataAreaId, salesLine.InventTransId),
StatusReceipt::None,
StatusIssue::ReservPhysical);
inventTransIdSumSingleStatus.parmInventDimCriteria(inventDim);
inventTransIdSumSingleStatus.parmInventDimParmCriteria(inventDimParmCriteria);
info(strFmt("%1", inventTransIdSumSingleStatus.reservPhysical()));
}
Mit Hilfe der Klasse InventTransIdSumSingleStatus kann man sich auch alle anderen Werte, wie beispielsweise die "In Auftrag" befindliche Menge. Dazu muss der Code nur minimal angepasst werden:
StatusReceipt::None,
StatusIssue::OnOrder);
inventTransIdSumSingleStatus.parmInventDimCriteria(inventDim);
inventTransIdSumSingleStatus.parmInventDimParmCriteria(inventDimParmCriteria);
info(strFmt("%1", inventTransIdSumSingleStatus.onOrder()));