Dynamics AX Blog - Microsoft Dynamics AX (Axapta) - Seite 19

Momentan angezeigt werden nur Beiträge der Kategorie »Microsoft Dynamics AX (Axapta)« Filter entfernen

In den letzten Jahren, in denen ich mich fast hauptsächlich mit der Entwicklung im Umfeld von Microsoft Dynamics AX (vormals Axapta) beschäftigt habe, ist das eine oder andere Code-Fragment entstanden, von dem ich mir vorstellen könnte, daß es auch für andere AX-Entwickler ganz nützlich sein könnte. Aber auch Tips und Tricks zu dem mächtigen ERP-System werde ich in dieser Kategorie präsentieren.

RSS-Feed dieser Kategorie

Produktionsauftrag per Code beenden

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 beendet.

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

static void prodEnd(Args _args)
{
    ProdTable prodTable;
    ProdMultiHistoricalCost prodMultiHistoricalCost;

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

    prodMultiHistoricalCost = ProdMultiHistoricalCost::construct(new Args());
    RunBaseMultiParm::initParm(prodMultiHistoricalCost);
    prodMultiHistoricalCost.insert(prodTable, prodMultiHistoricalCost.defaultParmBuffer());

    prodMultiHistoricalCost.run();
}

 
 

(Liefer-)Adresse einer Partei ermitteln

Der hier vorgestellt Job ermittelt die Lieferadresse eines Debitoren. Dabei wird die zuerst gefundene (sollte der Debitor mehrere Lieferadressen haben) über das Infolog ausgegeben.

Statt einem Debitoren kann natürlich jede andere Entität, die im Globalen Adressbuch gespeichert ist (Kreditoren, Personen, ...), abgefragt werden.

static void getAddressFromParty(Args _args)
{
    CustTable custTable = CustTable::find('US-003');
    Addressing addressing;

    // Get (first found) delivery address (denormalized)
    addressing =
    DirParty::getPostalAddressByType(custTable.Party, LogisticsLocationRoleType::Delivery);

    info(addressing);
}

Auf diese Art & Weise lassen sich natürlich auch andere Adressen ermitteln, im Beispiel die Zahlungsadresse:

static void getAddressFromParty(Args _args)
{
    CustTable custTable = CustTable::find('US-003');
    Addressing addressing;

    // Get (first found) payment address
    addressing =
    DirParty::getPostalAddressByType(custTable.Party, LogisticsLocationRoleType::Payment);

    info(addressing);
}

 
 

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();
}

 
 
Seiten « 1 ... 16 17 18 19 20 21 22 ... 52 » 

 

 
 
 
Beiträge des aktuellen Monats
Mai 2025
MoDiMiDoFrSaSo
 1234
567891011
12131415161718
19202122232425
262728293031 
 
© 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