Dynamics AX Blog - Beiträge vom Juli 2014

Momentan angezeigt werden nur Beiträge vom »Juli 2014«. Filter entfernen

Produktionsauftrag per Code fertigmelden

Screenshot

Dynamics AX stellt ein Framework zur Verfügung, mit dessen Hilfe man Produktionsaufträge in einen bestimmten Status überführen kann. Im Beispiel wird ein Produktionsauftrag fertig gemeldet.

Wenn man mehrere Aufträge gleichzeitig aktualisieren möchte, muss man die Methode ProdMultiReportFinished.insert() einfach entsprechend oft aufrufen und den jeweiligen Datensatz der ProdTable übergeben.

static void prodReportFinished(Args _args)
{
    ProdTable prodTable;
    ProdMultiReportFinished prodMultiReportFinished;

    prodTable = ProdTable::find("P000195");

    prodMultiReportFinished = ProdMultiReportFinished::construct(new Args());
    RunBaseMultiParm::initParm(prodMultiReportFinished);
    prodMultiReportFinished.insert(prodTable, prodMultiReportFinished.defaultParmBuffer());

    prodMultiReportFinished.run();
}
 

 
 
 

Produktionsauftrag per Code starten

Screenshot

Dynamics AX stellt ein Framework zur Verfügung, mit dessen Hilfe man Produktionsaufträge in einen bestimmten Status überführen kann. Im Beispiel wird ein Produktionsauftrag gestartet.

Wenn man mehrere Aufträge gleichzeitig aktualisieren möchte, muss man die Methode ProdMultiStartUp.insert() einfach entsprechend oft aufrufen und den jeweiligen Datensatz der ProdTable übergeben.

static void prodStartUp(Args _args)
{
    ProdTable prodTable;
    ProdMultiStartUp prodMultiStartUp;

    prodTable = ProdTable::find("P000160");

    prodMultiStartUp = ProdMultiStartUp::construct(new Args());
    RunBaseMultiParm::initParm(prodMultiStartUp);
    prodMultiStartUp.insert(prodTable, prodMultiStartUp.defaultParmBuffer());

    prodMultiStartUp.run();
}
 

 
 
 

Produktionsauftrag per Code freigeben

Screenshot

Dynamics AX stellt ein Framework zur Verfügung, mit dessen Hilfe man Produktionsaufträge in einen bestimmten Status überführen kann. Im Beispiel wird ein Produktionsauftrag freigegeben.

Wenn man mehrere Aufträge gleichzeitig aktualisieren möchte, muss man die Methode ProdMultiRelease.insert() einfach entsprechend oft aufrufen und den jeweiligen Datensatz der ProdTable übergeben.

static void prodRelease(Args _args)
{
    ProdTable prodTable;
    ProdMultiRelease prodMultiRelease;

    prodTable = ProdTable::find("P000177");

    prodMultiRelease = ProdMultiRelease::construct(new Args());
    RunBaseMultiParm::initParm(prodMultiRelease);
    prodMultiRelease.insert(prodTable, prodMultiRelease.defaultParmBuffer());

    prodMultiRelease.run();
}
 

 
 
 

Produktionsauftrag per Code vorkalkulieren

Screenshot

Dynamics AX stellt ein Framework zur Verfügung, mit dessen Hilfe man Produktionsaufträge in einen bestimmten Status überführen kann. Im Beispiel wird ein Produktionsauftrag vorkalkuliert.

Wenn man mehrere Aufträge gleichzeitig aktualisieren möchte, muss man die Methode ProdMultiCostEstimation.insert() einfach entsprechend oft aufrufen und den jeweiligen Datensatz der ProdTable übergeben.

static void prodCostEstimation(Args _args)
{
    ProdTable prodTable;
    ProdMultiCostEstimation prodMultiCostEstimation;

    prodTable = ProdTable::find("P000160");

    prodMultiCostEstimation =
    ProdMultiCostEstimation::construct(new Args());

    RunBaseMultiParm::initParm(prodMultiCostEstimation);
    prodMultiCostEstimation.insert(
        prodTable,
        prodMultiCostEstimation.defaultParmBuffer());

    prodMultiCostEstimation.run();
}

 


 
 
 

Produktionsauftrag per Code erstellen

Screenshot

Mit Hilfe des folgenden Jobs kann man sich per Code einen Produktionsauftrag erstellen. Leider habe ich in Dynamics AX weder eine AX<Table>-Klasse für die Prodtable gefunden (die ich persönlich ja sehr gerne verwende) noch irgendeine andere Klasse mit Hilfe derer man einen Produktionsauftrag erstellen kann.

static void createProdTable(Args _args)
{
    ProdQty         qty = 10;
    ItemId          itemId = "D0005";
    ProdTable       prodTable;
    InventTable     inventTable;

    inventTable = InventTable::find(itemId);

    prodTable.initValue();
    prodTable.initFromInventTable(inventTable);

    prodTable.ItemId = inventTable.ItemId;
    prodTable.modifiedField(fieldNum(ProdTable, ItemId));

    prodTable.QtySched = qty;
    prodTable.modifiedField(fieldNum(ProdTable, QtySched));

    prodTable.RemainInventPhysical = prodTable.QtySched;
    prodTable.modifiedField(fieldNum(ProdTable, RemainInventPhysical));

    prodTable.initBOMVersion();
    prodTable.initRouteVersion();

    prodTable.insert();
}

 
 
 

Ermitteln der reservierten Menge einer Auftragsposition für bestimmte Dimensionen

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.

static void getPhysicalReservedQtyForSalesLine(Args _args)
{
    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:


 
 
 

 

 
 
 
Beiträge des aktuellen Monats
Juli 2014
MoDiMiDoFrSaSo
 123456
78910111213
14151617181920
21222324252627
28293031 
 
© 2006-2025 Heinz Schweda | Impressum | Kontakt | English version | Mobile Version
Diese Webseite verwendet Cookies, um Benutzern einen besseren Service anzubieten. Wenn Sie weiterhin auf der Seite bleiben, stimmen Sie der Verwendung von Cookies zu.  Mehr dazu